Algoritmos de Ordenação e pesquisa

990 palavras 4 páginas
Pesquisa binária

#include <stdio.h>

#define TAMANHO 10

int main () { int vetor[TAMANHO] = {0,1,2,3,4,5,6,7,8,9}; int valor = 8; int encontrado;

int direita, esquerda, meio;

encontrado = 0; /*Falso*/

esquerda = 0; direita = TAMANHO - 1;

while (esquerda <= direita && !encontrado) { meio = (direita + esquerda) / 2; if (vetor[meio] == valor) encontrado = 1; /*Verdadeiro*/ else if (valor < vetor[meio]) direita = meio - 1; else esquerda = meio + 1; }

if (encontrado) { printf ("Valor %d encontrado na posicao %d\n", vetor[meio], meio); } else { printf ("Valor %d não encontrado\n", valor); }

return 0;
}
Algoritmos de Ordenação
Algoritmo de ordenação, em ciência da computação, é um algoritmo que coloca os elementos de uma dada sequência em uma certa ordem. Em outras palavras efetua sua ordenação completa ou parcial. O objetivo da ordenação é facilitar a recuperação dos dados de uma lista.
Para este artigo foram escolhidos alguns algoritmos de ordenação para serem estudados que são: Bubble Sort, Selection Sort, Quick Sort e Insertion Sort.
Bubble Sort
Bubble sort é o algoritmo mais simples, mas o menos eficientes. Neste algoritmo cada elemento da posição i será comparado com o elemento da posição i + 1, ou seja, um elemento da posição 2 será comparado com o elemento da posição 3. Caso o elemento da posição 2 for maior que o da posição 3, eles trocam de lugar e assim sucessivamente. Por causa dessa forma de execução, o vetor terá que ser percorrido quantas vezes que for necessária, tornando o algoritmo ineficiente para listas muito grandes.

Figura 2: Esquema de funcionamento do Buble Sort
É verificado se o 3 é maior que 5, por essa condição ser falsa, não há troca.
É verificado se o 5 é maior que 1, por essa condição ser verdadeira, há uma troca.
É verificado se o 5 é maior que 2, por essa condição ser verdadeira, há uma troca.
É verificado se o 5 é maior que 4, por essa condição ser

Relacionados

  • Classifica O E Pesquisa ETAPA 4
    1399 palavras | 6 páginas
  • Ordenacao 1x2
    1897 palavras | 8 páginas
  • Sistemas de Microprocessadores
    2810 palavras | 12 páginas
  • ATPS 2013 1 Cienc Computacao 4 Classificacao Pesquisa
    2989 palavras | 12 páginas
  • Métodos de Ordenação
    822 palavras | 4 páginas
  • 215741614 ATPS Classificacao e Pesquisa
    1655 palavras | 7 páginas
  • Pesquisa e Ordenação de dados
    775 palavras | 4 páginas
  • criptografia
    2370 palavras | 10 páginas
  • classificação e pesquisa
    1349 palavras | 6 páginas
  • Documentoartigos sobrre herança e polimorfismo em java
    1423 palavras | 6 páginas