我正在學習快速排序算法,但由於某種原因,此python實現的輸出只是部分排序,我得到了'最大遞歸深度達到'較大的輸入。在過去的幾天裏,我一直在抨擊我的頭,我知道這可能是一件非常愚蠢的事情,但我似乎無法弄清楚,所以我會很感激任何幫助。Python快速排序只是部分排序
def ChoosePivot(list):
return list[0]
def Partition(A,left,right):
p = ChoosePivot(A)
i = left + 1
for j in range(left + 1,right + 1): #upto right + 1 because of range()
if A[j] < p:
A[j], A[i] = A[i], A[j] #swap
i = i + 1
A[left], A[i - 1] = A[i-1], A[left] #swap
return i - 1
def QuickSort(list,left, right):
if len(list) == 1: return
if left < right:
pivot = Partition(list,left,right)
QuickSort(list,left, pivot - 1)
QuickSort(list,pivot + 1, right)
return list[:pivot] + [list[pivot]] + list[pivot+1:]
sample_array = [39,2,41,95,44,8,7,6,9,10,34,56,75,100]
print "Unsorted list: "
print sample_array
sample_array = QuickSort(sample_array,0,len(sample_array)-1)
print "Sorted list:"
print sample_array
你應該考慮更高層次的算法。這就是你如何用C這樣的語言寫出來的。在功能上考慮它會更好。 – 2012-04-06 06:19:56