我正在尝试在Python中实现快速排序。使用的是CLRS算法版本。
以下是我的代码。我认为它大部分情况下都能正常工作,除了列表的中间元素。
有人可以帮忙吗?
输出应该是
以下是我的代码。我认为它大部分情况下都能正常工作,除了列表的中间元素。
有人可以帮忙吗?
#! /usr/bin/python
#quick sort
def swap(array,i,j):
temp = array[i]
array[i] = array[j]
array[j] = temp
def partition(array, start,end):
x = array[end]
i = start -1
for j in xrange(start+1, end):
if (array[j] <= x):
i = i+1
swap (array,i,j)
swap(array,i+1,end)
return i+1
def quicksort(array,p,r):
if p<r:
q = partition(array,p,r)
quicksort(array,p,q-1)
quicksort(array,q+1,r)
def main():
unsortedArray = [2,8,7,1,3,5,6,4,9,0]
quicksort(unsortedArray,0,len(unsortedArray)-1)
print unsortedArray
if __name__ == '__main__':
main()
输出应该是
[0,1,2,3,4,5,6,7,8,9]
,但实际上它打印的是 [2, 0, 3, 4, 1, 6, 5, 7, 9, 8]
。