Быстрая сортировка с вставкой сортировки Python не работает

Я пытался запустить быструю сортировку с переключением на сортировку вставкой, когда размер подмассива меньше 10. Так что получается, я не получаю отсортированный список.

Куда я иду не так?

import random
import time

m = 0

def quicksort(numList, first, last):
    if first<last:
        sizeArr = last - first + 1
        if(sizeArr < m):
            insert_sort(numList, first, last)
        else:
            mid = partition(numList, first, last)
            quicksort(numList, first, mid-1)
            quicksort(numList, mid + 1, last)

def partition(numList, first, last):
    piv = numList[last]
    i = first-1
    for j in range(first,last):
        if numList[j] < piv:
            i += 1
            temp = numList[i]
            numList[i] = numList[j]
            numList[j] = temp

    tempo = numList[i+1]
    numList[i+1] = numList[last]
    numList[last] = tempo

    return i+1

def insert_sort(numList, first, last):
    for x in range(first, last):
        key = numList[x]
        y = x-1
        while y > -1 and numList[y]> key:
            numList[y+1] = numList[y]
            y = y-1
        numList[y+1] = key

if __name__ == '__main__':
    start = time.time()
    numList = random.sample(range(5000), 100)
    m = 10
    quicksort(numList, 0, len(numList) - 1)
    print numList
    print "Time taken: " + str(time.time() - start)

вход - это некоторый случайный массив размеров от 100 до 1000000. Я использую генератор случайных чисел, как вы можете видеть.

Пожалуйста, помогите мне.

1 ответ

Решение

У вас есть ошибка по одному insert_sort функция. Перебрать range(first, last+1) и это будет правильно сортировать.

Другие вопросы по тегам