Skip to content

Latest commit

 

History

History
229 lines (161 loc) · 10.2 KB

README.md

File metadata and controls

229 lines (161 loc) · 10.2 KB

Grupo 05: Busca de clientes com Jump Search

Doscente da turma

Componentes da equipe

Linguagem utilizada

C 

Sobre o projeto

Implemente um algoritmo que manipula um tipo estruturado Clientes e possui a funcionalidade de buscar clientes em um arquivo.

Os clientes devem ter os atributos básicos:

  • Nome;
  • Endereço;
  • Código do cliente;

Requisitos

  • A cada execução do programa, ele deve carregar os dados (Armazenados em um arquivo texto);
  • O programa deve perguntar ao usuário qual cliente ele deseja buscar por nome ou código com o algoritmo Jump Search;
  • Compute o tempo de execução do processo de busca;
  • Informe a complexidade do algoritmo Jump Search;

O que seria o Jump Search

O jump search é basicamente um algoritmo de busca eficiente para encontrar um determinado elemento em um array que está ordenado.

Também conhecido como Pesquisa por Salto, ele é chamado assim pois ao invés de pesquisar um elemento de forma linear, ele "salta" entre diferentes posições de um array com base em um cálculo matemático.

Permitindo, assim, que seja encontrado um elemento dentro de um array realizando um número menor de comparações do que em uma busca simples.

Quais as etapas desse algoritmo

  • 1- A pesquisa sempre começa no início do array.
  • 2- Defina o tamanho do salto: Para pesquisar utilizando este algoritmo, primeiramente é necessário definir um tamanho para este salto para determninar para qual posição do array pular a cada iteração. Geralmente desse valor é definido usando a raiz quadrada do tamanho total do array (ex. Se um array possui 100 posições, a cada iteração o algoritmo saltará 10 posições no array ).
  • 3- Compare os elementos com o valor desejado: Caso o valor desejado for igual ao valor lido ma posição do array, a pesquisa terminará e o valor será encontrado.
  • 4- Calcule a próxima posição de salto: Se o elemento na posição atual não for igual ao valor desejado, algoritmo calcula a próxima posição de salto usando o tamanho do salto.
  • 5- Caso o valor na posição atual do array for maior do que o valor que está sendo procurado, o algoritmo volta à posição do salto anterior e começa uma busca linear no array.

Vantagens

  • Mais eficiente que a busca linear: O Jump Search é mais eficiente que a busca linear, pois realiza menos comparações em média.
  • Menos eficiente que a busca binária: O Jump Search é menos eficiente que a busca binária, mas é mais fácil de implementar.

Desvantagens

  • Menos eficiente que a busca binária: O Jump Search é menos eficiente que a busca binária, especialmente para arrays grandes.
  • Pior caso: O pior caso do Jump Search é O(n), o mesmo que a busca linear.

Implementação

Pesquisa por código:

Declaração de variáveis:

usuarios: Array que armazena os dados dos usuários. n: Tamanho do array "usuarios". salto: Tamanho do salto a ser utilizado na busca. codigo: Código do usuário que está sendo buscado. posicao: Posição do usuário encontrado no array.

Cálculo do salto:

A variável "salto" é calculada como a raiz quadrada do tamanho do array "usuarios" (n). Essa fórmula garante um bom equilíbrio entre a eficiência da busca e a simplicidade do código.

Busca usando loop while:

Um loop while é usado para percorrer o array "usuarios" de forma eficiente. A condição do loop verifica se a posição atual (posicao) é menor que o código desejado (codigo). Se a condição for verdadeira, o loop realiza as seguintes ações: A variável "posicao" é incrementada em "salto". Se a nova posição for maior que o tamanho do array, o loop é encerrado.

Busca linear:

Se o loop while não encontrar o código desejado, uma busca linear é realizada para verificar se o código está presente em algum dos elementos restantes do array. A busca linear percorre o array elemento por elemento, comparando o código de cada elemento com o código desejado.

Retorno do resultado:

Se o código for encontrado, a função retorna a posição do elemento encontrado no array. Se o código não for encontrado, a função retorna -1.

Pesquisa por nome:

Parâmetros:

cliente: Ponteiro para um array de structs do tipo Cliente. QuantidadeDeClientes: Ponteiro para um inteiro que armazena o número de clientes no array. nome: Ponteiro para uma string que armazena o nome do cliente que está sendo buscado. Funcionamento:

Cálculo do salto:

A função calcula o tamanho do salto a ser utilizado na busca como a raiz quadrada do número de clientes (QuantidadeDeClientes).

Ordenação do array:

A função ordena o array de clientes por nome usando a função qsort. Essa ordenação é necessária para que a busca binária funcione corretamente.

Busca binária:

A função realiza uma busca binária no array ordenado para encontrar o cliente com o nome especificado.

A busca binária compara o nome do cliente com o nome do cliente no meio do array. Se o nome do cliente for menor que o nome do cliente no meio do array, a busca continua na metade inferior do array. Se o nome do cliente for maior que o nome do cliente no meio do array, a busca continua na metade superior do array. A busca continua até que o cliente seja encontrado ou que se determine que o cliente não existe no array.

Retorno do resultado:

Se o cliente for encontrado, a função retorna a posição do cliente no array. Se o cliente não for encontrado, a função retorna -1.

Análise de complexidade por nome

int jumpSearchNome(Cliente** cliente, int QuantidadeDeClientes, charnome)
{
  int salto = sqrt(QuantidadeDeClientes);//c1 -  1 vez
  int i = 0, j = 0;//c2 -  1 vez

  qsort((cliente), QuantidadeDeClientes, sizeof(Cliente), comparar_nome); //c3 -  1 vez

  while (i <QuantidadeDeClientes && strcmp((cliente)[i].Nome, nome) < 0)//c4 - sqrt N
  {
      i += salto; //c5 - sqrt N
  }
  if (i >=QuantidadeDeClientes || strcmp((cliente)[i].Nome, nome) > 0)
  {
      i -= salto; //c6 - 1 vez
      for (j = i; j < i + salto && j <QuantidadeDeClientes; j++) //c7 -  1 vez
      {
          if (strcmp((cliente)[j].Nome, nome) == 0)
          {
              return j; //c8 - sqrt N;
          }
      }
      return -1; //c9 - sqrt N;
  }
  else if (strcmp((cliente)[i].Nome, nome) == 0)
  {
      return i; //c10 - 1 vez
  }
  return -1;//c11 -  1 vez
}

Análise complexidade de tempo por código

int JumpSearchCod(Cliente *usuarios, intQuantidadeDeCliente, int codigo) {

  int posicaoAtual = 0; //C1 - 1 vez
  int salto = sqrt(QuantidadeDeCliente); //C2 - 1 vez

  qsort((usuarios),QuantidadeDeCliente, sizeof(Cliente), comparar_codigo); //C3 - 1 vez

  while (posicaoAtual < QuantidadeDeCliente) { //C4 - √n
      if ((usuarios)[posicaoAtual].CodigoCliente < codigo)  { //C5 - √n
          posicaoAtual += salto; //C6 - √n
      } else {
          break;//C6 - 1 vez
      }
  }


  for (int PosicaoLinear = posicaoAtual - salto; PosicaoLinear <QuantidadeDeCliente; PosicaoLinear++) { // C7 - √n
      if ((usuarios)[PosicaoLinear].CodigoCliente ==codigo) { //C8 - √n
          return PosicaoLinear;//C9 - 1 vez
      } 
  }

  return -1; //C10 - 1 vez
}

Resultado da análise de tempo

/*
    Quantidade de alunos = Pior caso e médio caso
    T(n) = (c1 + c2 + c5+ c6+ c9 + c10) + (c3 + c4 + c7 + c8)√n
    T(n) = a + b√n
    T(n) = b√n

    ou seja: O(√n)
    /


    /
    Quantidade de alunos = Pior caso
    T(n) = (c1 + c2 + c5+ c6+ c9 + c10) 
    T(n) = a
    T(n) = 1

    ou seja: O(1)
    */

Análise de complexidade de espaço

O algoritmo de busca por salto usa apenas um número constante de variáveis ​​para armazenar informações durante a execução, independentemente do tamanho do conjunto de dados que está sendo pesquisado. As principais variáveis ​​usadas são:

Índice atual: Armazena a posição atual do algoritmo no conjunto de dados. Valor de salto: Determina o tamanho do próximo salto que o algoritmo dará. Valor alvo: O valor que o algoritmo está procurando. Como o número de variáveis ​​permanece constante independentemente do tamanho do conjunto de dados, a complexidade de espaço do algoritmo é considerada constante.

Conclusão

Após desenvolver o algoritmo para busca de clientes por nome ou código utilizando o método Jump Search, podemos concluir que esta abordagem oferece uma maneira eficiente de localizar informações em grandes conjuntos de dados.

Durante a execução do programa, pudemos observar que o tempo necessário para encontrar o cliente desejado foi relativamente rápido, mesmo em arquivos de tamanho considerável. Isso demonstra a eficácia do algoritmo Jump Search em otimizar o processo de busca, resultando em uma experiência mais ágil para o usuário.

Ao analisar a complexidade do algoritmo, percebemos que o Jump Search possui uma complexidade de tempo de O(√n), onde 'n' é o número de elementos no arquivo de clientes. Isso significa que, apesar de não ser tão eficiente quanto algoritmos de busca como o Binary Search (O(log n)), o Jump Search ainda oferece um desempenho bastante satisfatório, especialmente em conjuntos de dados não ordenados.

Em suma, a implementação do algoritmo Jump Search nos permitiu criar um programa capaz de buscar clientes de forma rápida e eficiente, proporcionando uma experiência mais fluida ao usuário durante a utilização do sistema.