Python实现快速排序解析
**
画图理解快速排序的代码下标变化
**
先上代码:
def quick_sort(array, left, right):
if left < right:
q = partition(array, left, right)
quick_sort(array, left,q-1)
quick_sort(array,q+1, right)
def partition(array, left, right):
x = array[right]
i = left-1
for j in range(left, right):
if array[j] <= x:
i += 1
array[i], array[j] = array[j], array[i]
array[i+1], array[right] = array[right], array[i+1]
return i+1
if __name__ == '__main__':
a = [3,2,6,7,5]
quick_sort(a,0,4)
print(a)
如下图所示,即为代码运行过程中的下标和数组大小变化。
上例是比较简单的例子,中间的变化过程不多,比较容易看懂,接下来我们看一个比较复杂点的例子。如下图所示:
我们可以初步看出,在i和j移动的过程中,数组被分成了三个部分(分别用红色,黑色,白色表示),其中i和j就是分割线,并且红色部分的元素均比A[r]小,黑色部分的元素均比A[r]大。最后得出如最后一个数组所示的排序。
PS:程序运行中,抓住i和j的变化规律。
如有侵权,请联系删除。