python排序算法的实现-快速排序
2013-11-11 17:41
633 查看
1、 算法描述:
1.先从数列中取出一个数作为基准数。
2.分区过程,将比这个数大的数全放到它的右边,小于或等于它的数全放到它的左边。
3.再对左右区间重复第二步,直到各区间只有一个数。
2、python代码
结果:
[8, 10, 9, 6, 4, 16, 5, 13, 26, 18, 2, 45, 34, 23, 1, 7, 3]
[1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 13, 16, 18, 23, 26, 34, 45]
1.先从数列中取出一个数作为基准数。
2.分区过程,将比这个数大的数全放到它的右边,小于或等于它的数全放到它的左边。
3.再对左右区间重复第二步,直到各区间只有一个数。
2、python代码
#!/usr/bin/python # -*- coding: utf-8 -*- def sub_sort(array,low,high): key = array[low] while low < high: while low < high and array[high] >= key: high -= 1 while low < high and array[high] < key: array[low] = array[high] low += 1 array[high] = array[low] array[low] = key return low def quick_sort(array,low,high): if low < high: key_index = sub_sort(array,low,high) quick_sort(array,low,key_index) quick_sort(array,key_index+1,high) if __name__ == '__main__': array = [8,10,9,6,4,16,5,13,26,18,2,45,34,23,1,7,3] print array quick_sort(array,0,len(array)-1) print array
结果:
[8, 10, 9, 6, 4, 16, 5, 13, 26, 18, 2, 45, 34, 23, 1, 7, 3]
[1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 13, 16, 18, 23, 26, 34, 45]
相关文章推荐
- python实现排序算法一:快速排序
- 用Python实现八大排序算法--快速排序
- Python实现快速排序
- golang实现常用排序算法 --- 快速排序、堆排序等
- Python 快速排序 堆排序——Python实现一些算法持续更新
- 算法基础:排序(三)——快速排序——Python实现
- 快速排序的算法思想及Python版快速排序的实现示例
- Python实现快速排序
- 经典排序算法(一)--冒泡排序、快速排序java实现
- JAVA排序算法实现代码-快速(Quick Sort)排序
- 快速排序的c++实现 和 python 实现
- 快速排序python实现
- python实现快速排序
- Java实现-高效排序算法之快速排序
- 快速排序,归并排序,堆排序python实现
- 排序算法复习(Java实现)(一): 插入,冒泡,选择,Shell,快速排序
- 常用排序算法python实现:快速排序
- python实现快速排序
- 快速排序的算法思想及Python版快速排序的实现示例
- python实现快速排序