Os 10 algoritmos básicos e práticos que os programadores devem conhecer

Autora:Inventor quantificado - sonho pequeno, Criado: 2016-12-09 11:37:36, Atualizado: 2016-12-09 11:39:20

Os 10 algoritmos básicos e práticos que os programadores devem conhecer

  • Algoritmo um: Algoritmo de classificação rápida

A ordenação rápida é um algoritmo de ordenação desenvolvido por Tony Hall. Em condições médias, a ordenação de n objetos requer uma comparação nlogn; em condições piores, uma comparação n2 é necessária, mas isso não é comum. Na verdade, a ordenação rápida geralmente é significativamente mais rápida do que outros algoritmos nlogn, pois seu loop interno pode ser implementado com muita eficiência em a maioria das arquiteturas.

Ordenamento rápido usa a estratégia Divideandconquer para dividir uma lista em duas sub-listas.

O algoritmo segue os seguintes passos:

  • 1, escolher um elemento da coluna numérica, chamado pivô de referência,

  • 2, reordenar a coluna, colocando todos os elementos menores que o valor de referência na frente do valor de referência e todos os elementos maiores que o valor de referência na retaguarda do valor de referência (o mesmo número pode ir para qualquer lado); após a saída deste segmento, o valor de referência fica no meio da coluna; isso é chamado de operação de partição.

  • 3, recursivo: ordenação de subarreixas de elementos menores que o valor de referência e maiores que o valor de referência.

    A situação mais básica da regressão é que o tamanho da matriz é zero ou um, ou seja, sempre foi ordenado. Embora a regressão seja contínua, o algoritmo sempre sai, porque em cada iteração, ele coloca pelo menos um elemento em sua posição final.

Algoritmo 2: Algoritmo de classificação de pilhas

Heapsort é um algoritmo de classificação projetado para usar este tipo de estrutura de dados. O heapsort é uma estrutura de árvore quase totalmente binária, mas também satisfaz a propriedade do heapsort: o valor de chave ou índice de um sub-nodo é sempre menor que (ou maior que) o de seu pai.

A complexidade média de tempo para a ordenação de pilhas é O (nlogn).

O algoritmo segue os seguintes passos:

  • 1, criar uma pilha H [0..n-1]

  • 2, substituir a cabeça da pilha (max) e a cauda da pilha

  • 3, reduzir o tamanho da pilha para 1 e chamar shift_down ((0), com o objetivo de ajustar os dados do topo da nova matriz para a posição correspondente

  • 4, repita o passo 2 até que o tamanho da pilha seja 1.

  • Algoritmo 3: classificação e classificação

Mergesort é um algoritmo de classificação eficaz baseado em operações de agregação. O algoritmo é uma aplicação muito típica do método Divide and Conquer.

O algoritmo segue os seguintes passos:

  • 1, aplicação de um espaço de tamanho igual à soma de duas séries já ordenadas, que é usado para armazenar as séries depois da fusão

  • 2, definir dois ponteiros, com a posição inicial como a posição inicial de duas séries ordenadas

  • 3. Comparar os elementos apontados pelos dois ponteiros, escolher um elemento relativamente pequeno e colocá-lo no espaço de junção e mover o ponteiro para o próximo local

  • 4, repita o passo 3 até que um dos ponteiros chegue ao final da sequência

  • 5, copiar todos os elementos restantes da outra sequência diretamente para a ponta da sequência combinada

  • Algoritmo 4: Algoritmo de busca binária

Um algoritmo de busca por dois pontos é um algoritmo de busca por um determinado elemento em uma matriz ordenada. O processo de pesquisa começa no elemento intermediário da matriz e termina se o elemento intermediário for exatamente o elemento a ser procurado; se um determinado elemento for maior ou menor que o elemento intermediário, o processo de pesquisa é feito na metade da matriz que é maior ou menor que o elemento intermediário, e a comparação começa do mesmo modo. O que é isso? Algoritmo 5: BFPRT (algoritmo de busca linear)

O BFPRT resolve o clássico problema de escolher o k maior (k menor) elemento de uma sequência de n elementos e, por meio de uma análise habilidosa, garante que o algoritmo permaneça com uma complexidade de tempo linear no pior dos casos. A idéia do algoritmo é semelhante à idéia de ordenação rápida.

O algoritmo segue os seguintes passos:

  • 1, dividindo n elementos em grupos de 5 em grupos de n / 5 (em cima da borda).

  • 2, extrair o número médio de cada grupo, qualquer método de ordenação, como inserir ordenação.

  • O algoritmo de seleção de chamadas recorrentes, que busca o mediano de todos os medianos do passo anterior, é definido como x e, em casos de medianos pares, é definido como escolher o menor do meio.

  • 4, para dividir um conjunto de números com x, é necessário que os números menores que x sejam k e maiores que x sejam n - k.

  • 5, se i==k, retorna x; se ik, retorna para encontrar o elemento menor que i-k no elemento maior que x.

    Condição de terminação: quando n = 1, o que é devolvido é o elemento i pequeno.

  • Algoritmo 6: DFS (Search Priority Deep)

O Deep-First-Search é um algoritmo de pesquisa que percorre os pontos da árvore ao longo da profundidade da árvore e ramifica a árvore o mais profundamente possível. Quando todos os lados do ponto v são explorados, a pesquisa retorna ao ponto inicial do lado do ponto v encontrado. O processo continua até que todos os pontos já encontrados sejam acessados pelo ponto de origem.

A busca de prioridade profunda é um algoritmo clássico em gráficos, que pode ser usado para gerar uma tabela topográfica correspondente a um gráfico de destino. A utilização de tabela topográfica pode ser usada para resolver facilmente muitos problemas gráficos relacionados, como o problema do caminho máximo, etc.

A partir de agora, o Google vai continuar a trabalhar com o Google para criar um algoritmo de gráficos mais rápido.

  • 1, acesso ao topo v;

  • 2, em sequência, a partir de pontos vizinhos não acessados de v, percorre o gráfico com prioridade de profundidade; até que todos os vértices do gráfico com o caminho de v sejam acessados;

  • 3, se ainda houver vertices não visitados no gráfico, recomece a percorrer a profundidade de prioridade a partir de um dos vertices não visitados até que todos os vertices do gráfico tenham sido visitados.

    A descrição acima pode ser mais abstrata, como por exemplo:

    O DFS, depois de começar em um dos picos v no gráfico de acesso, sai de v, acessa qualquer um dos seus picos adjacentes w1; parte de w1, acessa o pico w2 adjacente a w1 mas que ainda não foi visitado; e parte de w2, faz uma visita semelhante,... e assim por diante, até chegar a um pico u onde todos os picos adjacentes foram visitados.

    Em seguida, volte um passo atrás e volte ao topo que você visitou na última vez para ver se há outros picos adjacentes que não foram visitados. Se houver, visite esse topo e, em seguida, continue a partir deste topo para fazer uma visita semelhante à anterior. Se não houver, volte um passo atrás e faça uma pesquisa.

  • Algoritmo 7: BFS (Broadness Priority Search)

Breadth-First-Search é um algoritmo de busca gráfica. Simplificando, o BFS é um algoritmo de busca gráfica que percorre a largura da árvore, começando no ponto da raiz. Se todos os pontos forem visitados, o algoritmo é interrompido.

O algoritmo segue os seguintes passos:

  • Primeiro, coloque o nó raiz na fila.

  • 2. Retire o primeiro nó da fila e verifique se ele é um alvo.

    Se encontrarmos o alvo, terminamos a busca e enviamos o resultado. Caso contrário, todos os seus sub-nodos diretos que ainda não foram verificados são adicionados à fila.

  • 3, se a fila estiver vazia, significa que o gráfico inteiro foi examinado e que não há nenhum alvo no gráfico.

  • 4, repita o passo 2.

  • Algoritmo 8: Algoritmo Dijkstra

O algoritmo Dijkstra foi desenvolvido pelo cientista de computadores holandês Eichel Dijkstra. O algoritmo Dijkstra usa uma busca de largura de prioridade para resolver o problema do caminho mais curto de um único fonte de um gráfico orientado não-negativo, resultando em uma árvore de caminho mais curto. O algoritmo é frequentemente usado em algoritmos de roteamento ou como um submodular de outros algoritmos gráficos.

A entrada do algoritmo contém um gráfico orientado ponderado G, e um vértice de origem S em G. V representa o conjunto de todos os vértices em G. Cada lado do gráfico é um par de elementos ordenados formados por dois vértices. U, v significa que há um caminho entre os vértices u e v. E representa o conjunto de todos os lados em G, e o peso do lado é definido pela função de ponderação w: E→[0,∞].

Assim, w ((u, v) é o peso não negativo do topo u até o topo v. O peso do lado pode ser imaginado como a distância entre os dois picos. O peso do caminho entre os dois pontos é a soma dos pesos de todos os lados do caminho. Há um topo s e t em V, e o algoritmo de Dijkstra pode encontrar o menor caminho de peso de s a t.

O algoritmo segue os seguintes passos:

  • 1, o valor da distância correspondente ao ponto no T, quando S = {V0}, T = {residual vertices} Se existir, d ((V0,Vi) é o valor de peso no arco Se não existe, d ((V0, Vi) é ∞

  • 2, escolha um topo W de T cujo valor de distância seja o menor e não esteja em S e junte S

  • 3, modificação do valor da distância entre os vértices do resto de T: se adicionar W como um vértice intermediário, reduzindo o valor da distância de V0 para Vi, modifica-se este valor de distância

    Repita os passos 2 e 3 até que o S contenha todos os vertices, ou seja, W = Vi.

  • Algoritmo 9: Algoritmo de planejamento dinâmico

A programação dinâmica é um método usado em matemática, ciência da computação e economia para resolver problemas complexos por meio da decomposição de problemas originais em subproblemas relativamente simples. A programação dinâmica é frequentemente aplicada a problemas com subproblemas sobrepostos e estruturas de suporte ideal, que costumam demorar muito menos do que soluções simples.

A ideia básica por trás do planejamento dinâmico é muito simples. Geralmente, para resolver um problema, precisamos resolver seus diferentes componentes ("problemas de sub-problemas") e resolver subproblemas de recombinação para resolver o problema original. Muitos subproblemas são muito semelhantes, por isso o planejamento dinâmico tenta resolver cada subproblemas apenas uma vez, reduzindo assim o volume de computação: uma vez que a solução de um dado subproblemas foi calculada, ele é armazenado em memória para ser verificado diretamente na próxima vez que for necessário resolver o mesmo subproblemas.

A questão mais clássica do planejamento dinâmico é a questão da mochila.

O algoritmo segue os seguintes passos:

1, Propriedade estrutural ideal. Se a solução para o subproblema que contém a melhor solução do problema também é ideal, o problema é chamado de subestrutural ideal (isto é, satisfaz o princípio da otimização); a estrutura ideal fornece pistas importantes para a solução de problemas em algoritmos de planejamento dinâmico.

2, a sobreposição de subproblemas. A sobreposição de subproblemas refere-se ao fato de que, quando um problema é resolvido de cima para baixo com um algoritmo recursivo, cada vez que um subproblema é gerado, não é sempre um novo problema, e alguns subproblemas são calculados várias vezes. O algoritmo de planejamento dinâmico aproveita a sobreposição de subproblemas, calcula cada subproblema uma vez e mantém seus resultados em uma tabela. O que é isso? - Algoritmo 10: Algoritmo de classificação Bayesian simples

Um algoritmo de classificação de Bayes simples é um algoritmo de classificação de probabilidade simples baseado no teorema de Bayes. O algoritmo de classificação de Bayes baseia-se no raciocínio de probabilidade, ou seja, como realizar as tarefas de raciocínio e de decisão quando as condições são incertas e apenas se sabe que elas ocorrem. O raciocínio de probabilidade corresponde ao raciocínio de certeza.

Os classificadores de Bayes simples dependem de modelos de probabilidade natural precisos e obtêm muito bons efeitos de classificação em conjuntos de amostras com aprendizado supervisionado. Em muitas aplicações práticas, os parâmetros do modelo de Bayes simples são estimados usando o método de estimativa da maior similaridade, ou seja, os modelos de Bayes simples funcionam sem o uso de probabilidades de Bayes ou de qualquer modelo de Bayes.

Apesar dessas idéias simples e suposições muito simplificadas, os classificadores Bayesian simples podem funcionar bastante bem em muitas situações de realidade complexas.


Mais informações