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的变化规律。

如有侵权,请联系删除。

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值