python递归实现快速排序


Posted in Python onAugust 18, 2018

快速排序(QuickSort)是对冒泡排序的一种改进:

基本思想:

通过一趟排序将要排序的数据分割成独立的两部分,其中一部分的所有数据都比另外一部分的所有数据都要小,然后再按此方法对这两部分数据分别进行快速排序,整个排序

过程可以递归进行,以此达到整个数据变成有序序列。

一趟快速排序的算法是:

1)设置两个变量i、j,排序开始的时候:i=0,j=N-1;

2)以第一个数组元素作为关键数据,赋值给key,即key=A[0];

3)从j开始向前搜索,即由后开始向前搜索(j--),找到第一个小于key的值A[j],将A[j]和A[i]互换;

4)从i开始向后搜索,即由前开始向后搜索(i++),找到第一个大于key的A[i],将A[i]和A[j]互换;

5)重复第3、4步,直到i=j; (3,4步中,没找到符合条件的值,即3中A[j]不小于key,4中A[i]不大于key的时候改变j、i的值,使得j=j-1,i=i+1,直至找到为止。找到符合条件的值,

进行交换的时候i, j指针位置不变。另外,i==j这一过程一定正好是i+或j-完成的时候,此时令循环结束)。

利用python实现的快速排序代码quick_sort.py如下:

def sub_sort(array,low,high):
  pivotkey=array[low]
  while low<high :
    while low<high and array[high]>=pivotkey:
      high -= 1
    array[low]=array[high]
    while low<high and array[low]<=pivotkey:
      low += 1
    array[high]=array[low]
  array[low]=pivotkey
  return low
 
def quick_sort(array,low,high):
  if low < high :
    pivoloc=sub_sort(array,low,high)
    quick_sort(array,low,pivoloc-1)
    quick_sort(array,pivoloc+1,high)
 
if __name__=="__main__": 
  array=[49,38,65,97,76,13,27]
  print array
  quick_sort(array,0,len(array)-1)
  print array

对一个数组array=[49, 38, 65, 97, 76, 13, 27]进行快速排序,得到的结果如下所示:

=============== RESTART: I:\python_DataStructure\quick_sort.py ===============
[49, 38, 65, 97, 76, 13, 27]
[13, 27, 38, 49, 65, 76, 97]
>>>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
举例讲解Python设计模式编程中的访问者与观察者模式
Jan 26 Python
Python编程之string相关操作实例详解
Jul 22 Python
Python数据分析matplotlib设置多个子图的间距方法
Aug 03 Python
Python基础教程之异常详解
Jan 10 Python
Python3 执行Linux Bash命令的方法
Jul 12 Python
Ubuntu+python将nii图像保存成png格式
Jul 18 Python
python如何将两个txt文件内容合并
Oct 18 Python
如何基于pythonnet调用halcon脚本
Jan 20 Python
Python xmltodict模块安装及代码实例
Oct 05 Python
举例讲解Python装饰器
Dec 24 Python
python使用Windows的wmic命令监控文件运行状况,如有异常发送邮件报警
Jan 30 Python
Python 详解通过Scrapy框架实现爬取百度新冠疫情数据流程
Nov 11 Python
pyqt5的QWebEngineView 使用模板的方法
Aug 18 #Python
python递归全排列实现方法
Aug 18 #Python
python使用PIL给图片添加文字生成海报示例
Aug 17 #Python
Python在for循环中更改list值的方法【推荐】
Aug 17 #Python
Python简单读写Xls格式文档的方法示例
Aug 17 #Python
Python实现的连接mssql数据库操作示例
Aug 17 #Python
Python SQL查询并生成json文件操作示例
Aug 17 #Python
You might like
php实现rc4加密算法代码
2012/04/25 PHP
详解PHP中的mb_detect_encoding函数使用方法
2015/08/18 PHP
PHP自定义函数实现格式化秒的方法
2016/09/14 PHP
详谈php静态方法及普通方法的区别
2016/10/04 PHP
PHP清除缓存的几种方法总结
2017/09/12 PHP
Yii2 中实现单点登录的方法
2018/03/09 PHP
IE和firefox浏览器的event事件兼容性汇总
2009/12/06 Javascript
提升你网站水平的jQuery插件集合推荐
2011/04/19 Javascript
读jQuery之九 一些瑕疵说明
2011/06/21 Javascript
JQuery选择器特辑 详细小结
2012/05/14 Javascript
jquery插件开发之实现jquery手风琴功能分享
2014/03/10 Javascript
js生成的验证码的实现与技术分析
2014/09/17 Javascript
js实现div弹出层的方法
2014/11/20 Javascript
javascript删除数组重复元素的方法汇总
2015/06/24 Javascript
javascript中错误使用var造成undefined
2016/03/31 Javascript
JS数组去掉重复数据只保留一条的实现代码
2016/08/11 Javascript
前端实现文件的断点续传(前端文件提交+后端PHP文件接收)
2016/11/04 Javascript
Angularjs Ng_repeat中实现复选框选中并显示不同的样式方法
2018/09/12 Javascript
vue cli3 调用百度翻译API翻译页面的实现示例
2019/09/13 Javascript
vue学习笔记之Vue中css动画原理简单示例
2020/02/29 Javascript
JS实现放烟花效果
2020/03/10 Javascript
js+canvas实现转盘效果(两个版本)
2020/09/13 Javascript
Python编程实现粒子群算法(PSO)详解
2017/11/13 Python
python不换行之end=与逗号的意思及用途
2017/11/21 Python
python进行TCP端口扫描的实现
2018/12/21 Python
Python 脚本获取ES 存储容量的实例
2018/12/27 Python
Python configparser模块操作代码实例
2020/06/08 Python
使用python画出逻辑斯蒂映射(logistic map)中的分叉图案例
2020/12/11 Python
HTML5 canvas画图并保存成图片的jcanvas插件
2014/01/17 HTML / CSS
美国在线眼镜店:GlassesShop
2018/11/15 全球购物
PHP经典面试题
2016/09/03 面试题
车祸赔偿收入证明
2014/01/09 职场文书
建设幸福中国演讲稿
2014/09/11 职场文书
2015年度物流工作总结
2015/04/30 职场文书
身份证丢失证明
2015/06/19 职场文书
听证会主持词
2015/07/03 职场文书