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

快速排序算法

  • 折半/二分查找算法
  • 冒泡排序算法
  • 插入排序算法
  • 选择排序算法
  • 快速排序算法
  • 希尔排序算法
  • 堆排序算法
  • 归并排序算法

这里是从小到大排列

原理:

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

图解

数据结构:快速排序算法,详解,图解 -- 数据结构算法集_第1张图片

详细流程

快速排序算法通过多次比较和交换来实现排序,其排序流程如下:
(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)

结果:
数据结构:快速排序算法,详解,图解 -- 数据结构算法集_第2张图片

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

参考:
百科

你可能感兴趣的:(数据结构与算法,python)