""" Carlos J Corrada Bravo Este programa calcula el promedio de tiempo de ejecuciĆ³n de cuatro algoritmos de ordenamiento La variable maxValor define el valor maximo de los elementos de la lista La variable largoLista define el largo de las listas a ordenar La variable veces define las veces que se va a hacer el ordenamiento Al final se imprimen los promedios de cada algortimo """ from random import randint import time def mergeSort(lista): #definan el algoritmo de ordenamiento mergesort return lista def heapSort(lista): #definan el algoritmo de ordenamiento heapsort return lista def quickSort(lista): #definan el algoritmo de ordenamiento quicksort return lista def shellSort(lista): #definan el algoritmo de ordenamiento shellsort #El algoritmo compara elementos de una lista #que tienen una distancia fija entre ellos, la #differencia en distancia se minimiza por cada #iterazion del algoritmo num = int(len(lista)) dif = int(num/2) while dif > 0: for i in range(int(dif),int(num)): a = lista[i] j = i #por cada intervalo se reorganizara los elementos #si se cumple la declaracion dentro del while loop while j >= dif and lista[int(j - dif)] > a: lista[int(j)] = lista[int(j - dif)] j -= dif lista[int(j)] = a dif/= 2 return lista maxValor=1000 #define el valor maximo de los elementos de la lista largoLista=1000 #define el largo de las listas a ordenar veces=100 #define las veces que se va a hacer el ordenamiento acumulaMerge=0 #variable para acumular el tiempo de ejecucion del mergesort acumulaHeap=0 #variable para acumular el tiempo de ejecucion del heapsort acumulaQuick=0 #variable para acumular el tiempo de ejecucion del quicksort acumulaShell=0 #variable para acumular el tiempo de ejecucion del shellsort for i in range(veces): lista = [randint(0,maxValor) for r in range(largoLista)] #creamos una lista con valores al azar t1 = time.clock() #seteamos el tiempo al empezar mergeSort(lista) #ejecutamos el algoritmo mergeSort acumulaMerge+=time.clock()-t1 #acumulamos el tiempo de ejecucion t1 = time.clock() #seteamos el tiempo al empezar heapSort(lista) #ejecutamos el algoritmo heapSort acumulaHeap+=time.clock()-t1 #acumulamos el tiempo de ejecucion t1 = time.clock() #seteamos el tiempo al empezar quickSort(lista) #ejecutamos el algoritmo quickSort acumulaQuick+=time.clock()-t1 #acumulamos el tiempo de ejecucion t1 = time.clock() #seteamos el tiempo al empezar shellSort(lista) #ejecutamos el algoritmo shellSort acumulaShell+=time.clock()-t1 #acumulamos el tiempo de ejecucion #imprimos los resultados print ("Promedio de tiempo de ejecucion de " + str(veces) + " listas de largo " + str(largoLista)) print ("MergeSort " + str(acumulaMerge/veces) + " segundos") print ("HeapSort " + str(acumulaHeap/veces) + " segundos") print ("QuickSort " + str(acumulaQuick/veces) + " segundos") print ("ShellSort " + str(acumulaShell/veces) + " segundos")