数据结构:快速排序算法,详解,图解 -- 数据结构算法集

快速排序算法

这里是从小到大排列

原理:

从待排序序列中取一个元素为基准(任意选取,可以取开头、结尾或者中间元素),
把剩下元素依次与基准元素比较,大于基准元素放在右边,小于基准元素放在左边,
这样就能得到基准元素在原序列中的位置,再把左右的元素序列进行重复上面操作(递归),即可完成排序。

图解

在这里插入图片描述

详细流程

快速排序算法通过多次比较和交换来实现排序,其排序流程如下:
(1)首先设定一个分界值,通过该分界值将数组分成左右两部分。
(2)将大于或等于分界值的数据集中到数组右边,小于分界值的数据集中到数组的左边。
   此时,左边部分中各元素都小于或等于分界值,而右边部分中各元素都大于或等于分界值。
(3)然后,左边和右边的数据可以独立排序。对于左侧的数组数据,又可以取一个分界值,
   将该部分数据分成左右两部分,同样在左边放置较小值,右边放置较大值。右侧的数组数据也可以做类似处理。
(4)重复上述过程,可以看出,这是一个递归定义。通过递归将左侧部分排好序后,
   再递归排好右侧部分的顺序。当左、右两个部分各数据排序完成后,整个数组的排序也就完成了

代码实现

# _*_encoding:utf-8_*_


# 快速排序
def rapid_sort(lists):
	if len(lists) >= 2:
		# 选取基准元素,任意选取,开头、结尾、中间都可
		mid = lists[0]
		left, right = [], []		# 基准左右的list
		lists.remove(mid) 			# 原序列中删除基准元素
		for i in lists:				# 遍历剩下元素,进行分类
			if i > mid:
				right.append(i)
			else:
				left.append(i)
		return rapid_sort(left) + [mid] + rapid_sort(right)	# 递归	
	else:
		return lists


if __name__ == '__main__':
	lt = [3,6,1,8,4,9]
	print rapid_sort(lt)

结果:
在这里插入图片描述

文章中有不足之处请多多指教,欢迎讨论,共同学习,共同进步

参考:
百科

  • 3
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值