Coder Social home page Coder Social logo

bcribas / benchmark-ordenacao Goto Github PK

View Code? Open in Web Editor NEW
76.0 1.0 15.0 58 KB

Benchmark simples para algoritmos de ordenação. Envolve conteúdo da disciplina EDA-2 da UnB/FGA

License: GNU General Public License v2.0

Makefile 6.89% C 89.46% Shell 2.56% C++ 1.08%
sorting quicksort insertionsort bubblesort selectionsort shellsort heapsort quicksort-algorithm

benchmark-ordenacao's People

Contributors

andremralves avatar bcribas avatar brendavsantos avatar chfleury avatar eduard0803 avatar erickmvdo avatar iagorrr avatar joao-moura avatar soaresrlucas avatar thalisson-alves avatar

Stargazers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar

Watchers

 avatar

benchmark-ordenacao's Issues

BubbleSort com sentinela

Falta uma implementação do BubbleSort que tenha o sentinela de trocas, para que o algoritmo aproveite o estado quase ordenado do vetor.

Algoritmo baseado em BST

Adicionar os seguintes algoritmos para ordenação:

  • Árvore Binária de Busca
  • Árvore Binária de Busca - com entrada aleatorizada
  • Árvore RedBlack
  • Implementação utilizando a biblioteca de <search.h>, para árvores, da libc
  • Implementação utilizando set/map do C++

Todos os algoritmos acima, descritos, devem ser modificados para que seja possível armazenar chaves repetidas (a dica é armazenar um contador de elementos para cada chave)

make testesimples permite algoritmos que não tratem repetição

Como o make testesimples utiliza apenas o arquivo input/10-reverso é possível que algoritmos que não tratem repetição resultem na mesma md5, dando a ilusão de corretude do algoritmo.

Exemplo

Utilizando um set do c++ para inserir os elementos (que ignora repetições) e depois iterando sobre os elementos gera o mesmo md5.

cppsetsort

#include <stdio.h>
#include <set>
#include "ordenacaomacros.h"

using namespace std;

struct Compare
{
  bool operator()(const Item &a,const Item &b) const
  {
    return less(a,b);
  }
};

int main(void)
{
  int t;
  int r;
  r=scanf("%d",&t);
  set<Item, Compare> st;
  for(int i=0;i<t;++i){
    Item it;
    r=scanf("%d",&it);
    st.insert(it);
  }
    

  for(auto &x : st)
    r=printf("%d\n",x);
  return 0;
}

Output do make testesimples

dummy 78968b953a8809e7af12ff461fa92e8a  -
bubblesort d9921bfb7d3f63b496265bdc0564b5b8  -
bubblesortsentinela d9921bfb7d3f63b496265bdc0564b5b8  -
combsort d9921bfb7d3f63b496265bdc0564b5b8  -
selectionsort d9921bfb7d3f63b496265bdc0564b5b8  -
selectionsortR d9921bfb7d3f63b496265bdc0564b5b8  -
insertionsortslow d9921bfb7d3f63b496265bdc0564b5b8  -
insertionsort d9921bfb7d3f63b496265bdc0564b5b8  -
shellsort d9921bfb7d3f63b496265bdc0564b5b8  -
quicksort d9921bfb7d3f63b496265bdc0564b5b8  -
quicksortinsertion d9921bfb7d3f63b496265bdc0564b5b8  -
quicksortM3 d9921bfb7d3f63b496265bdc0564b5b8  -
quicksortM3insertion d9921bfb7d3f63b496265bdc0564b5b8  -
mergesort d9921bfb7d3f63b496265bdc0564b5b8  -
insertionsortmetades d9921bfb7d3f63b496265bdc0564b5b8  -
systemqsort d9921bfb7d3f63b496265bdc0564b5b8  -
introsortquickmerge d9921bfb7d3f63b496265bdc0564b5b8  -
introsortquickmergelongjmp d9921bfb7d3f63b496265bdc0564b5b8  -
introsortquickheaplongjmp d9921bfb7d3f63b496265bdc0564b5b8  -
radixsort d9921bfb7d3f63b496265bdc0564b5b8  -
redblacktreesort d9921bfb7d3f63b496265bdc0564b5b8  -
cppsort d9921bfb7d3f63b496265bdc0564b5b8  -
cppsetsort d9921bfb7d3f63b496265bdc0564b5b8  -
pqsortsimple d9921bfb7d3f63b496265bdc0564b5b8  -
heapsort d9921bfb7d3f63b496265bdc0564b5b8  -
countingsort d9921bfb7d3f63b496265bdc0564b5b8  -

Fazendo as seguites alterações no make testesimples observa-se que que o md5 se altera, visto que o set eliminará os elementos repetidos produzindo um resultado diferente.

make testesimples

testesimples: $(BINARY)
	@for B in $(BINARY); do \
		REVERSO=$$(./$$B < input/10-reverso          | md5sum | cut -d ' ' -f 1); \
		REPETIDO=$$(./$$B < input/10-muitosrepetidos | md5sum | cut -d ' ' -f 1); \
		printf "$$B - [$$REVERSO]  [$$REPETIDO]\n"; \
	done

output :

dummy - [78968b953a8809e7af12ff461fa92e8a]  [f26514f89d6a83f820d2d0b5f37a13fb]
bubblesort - [d9921bfb7d3f63b496265bdc0564b5b8]  [d9f1169747cb90c598263d8aa517332e]
bubblesortsentinela - [d9921bfb7d3f63b496265bdc0564b5b8]  [d9f1169747cb90c598263d8aa517332e]
combsort - [d9921bfb7d3f63b496265bdc0564b5b8]  [d9f1169747cb90c598263d8aa517332e]
selectionsort - [d9921bfb7d3f63b496265bdc0564b5b8]  [d9f1169747cb90c598263d8aa517332e]
selectionsortR - [d9921bfb7d3f63b496265bdc0564b5b8]  [d9f1169747cb90c598263d8aa517332e]
insertionsortslow - [d9921bfb7d3f63b496265bdc0564b5b8]  [d9f1169747cb90c598263d8aa517332e]
insertionsort - [d9921bfb7d3f63b496265bdc0564b5b8]  [d9f1169747cb90c598263d8aa517332e]
shellsort - [d9921bfb7d3f63b496265bdc0564b5b8]  [d9f1169747cb90c598263d8aa517332e]
quicksort - [d9921bfb7d3f63b496265bdc0564b5b8]  [d9f1169747cb90c598263d8aa517332e]
quicksortinsertion - [d9921bfb7d3f63b496265bdc0564b5b8]  [d9f1169747cb90c598263d8aa517332e]
quicksortM3 - [d9921bfb7d3f63b496265bdc0564b5b8]  [d9f1169747cb90c598263d8aa517332e]
quicksortM3insertion - [d9921bfb7d3f63b496265bdc0564b5b8]  [d9f1169747cb90c598263d8aa517332e]
mergesort - [d9921bfb7d3f63b496265bdc0564b5b8]  [d9f1169747cb90c598263d8aa517332e]
insertionsortmetades - [d9921bfb7d3f63b496265bdc0564b5b8]  [d9f1169747cb90c598263d8aa517332e]
systemqsort - [d9921bfb7d3f63b496265bdc0564b5b8]  [d9f1169747cb90c598263d8aa517332e]
introsortquickmerge - [d9921bfb7d3f63b496265bdc0564b5b8]  [d9f1169747cb90c598263d8aa517332e]
introsortquickmergelongjmp - [d9921bfb7d3f63b496265bdc0564b5b8]  [d9f1169747cb90c598263d8aa517332e]
introsortquickheaplongjmp - [d9921bfb7d3f63b496265bdc0564b5b8]  [d9f1169747cb90c598263d8aa517332e]
radixsort - [d9921bfb7d3f63b496265bdc0564b5b8]  [d9f1169747cb90c598263d8aa517332e]
redblacktreesort - [d9921bfb7d3f63b496265bdc0564b5b8]  [d9f1169747cb90c598263d8aa517332e]
cppsort - [d9921bfb7d3f63b496265bdc0564b5b8]  [d9f1169747cb90c598263d8aa517332e]
cppsetsort - [d9921bfb7d3f63b496265bdc0564b5b8]  [5e8c1c01f31c73ba3f2d4d119a0cccab]
pqsortsimple - [d9921bfb7d3f63b496265bdc0564b5b8]  [d9f1169747cb90c598263d8aa517332e]
heapsort - [d9921bfb7d3f63b496265bdc0564b5b8]  [d9f1169747cb90c598263d8aa517332e]
countingsort - [d9921bfb7d3f63b496265bdc0564b5b8]  [d9f1169747cb90c598263d8aa517332e]

IntroSort

Agora que temos o HeapSort, podemos implementar o introsort corretamente.

Será que algum aluno resolve esta demanda? :)

Separar os algoritmos pela complexidade no README

  • Montar uma tabela e separar os algoritmos de acordo com as suas complexidades.
  • Pequena descrição das técnicas de cada algoritmo
    • especialmente nos algoritmos que possuem várias versões
      • Quais as diferenças?
      • Há algum impacto assintótico?

MergeSort com InsertionSort

Aplicar a mesma estratégia do QuickSort no MergeSort. Fazendo com que o algoritmo deixe o vetor quase ordenado e finalize com uma passada do InsertionSort. Qual o tamanho ideal para os chunks não ordenados? Esta técnica melhora o desempenho de alguma forma?

RadixSort

Precisamos de uma implementação do RadixSort. Quem pode contribuir?

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.