快速排序算法
这里是从小到大排列
原理:
从待排序序列中取一个元素为基准(任意选取,可以取开头、结尾或者中间元素),
把剩下元素依次与基准元素比较,大于基准元素放在右边,小于基准元素放在左边,
这样就能得到基准元素在原序列中的位置,再把左右的元素序列进行重复上面操作(递归),即可完成排序。
图解
详细流程
快速排序算法通过多次比较和交换来实现排序,其排序流程如下:
(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)
结果:
文章中有不足之处请多多指教,欢迎讨论,共同学习,共同进步
参考:
百科