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调用java模块SmartXLS和jpype修改excel文件的方法
Apr 28 Python
python自带的http模块详解
Nov 06 Python
浅谈pandas中DataFrame关于显示值省略的解决方法
Apr 08 Python
用Python将结果保存为xlsx的方法
Jan 28 Python
Python控制Firefox方法总结
Jun 03 Python
PyQt5 加载图片和文本文件的实例
Jun 14 Python
python 字典有序并写入json文件过程解析
Sep 30 Python
PyTorch中的Variable变量详解
Jan 07 Python
Python AutoCAD 系统设置的实现方法
Apr 01 Python
在python中利用pycharm自定义代码块教程(三步搞定)
Apr 15 Python
python如何导出微信公众号文章方法详解
Aug 31 Python
Python turtle编写简单的球类小游戏
Mar 31 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 404错误页面实现代码
2009/06/22 PHP
关于laravel后台模板laravel-admin select框的使用详解
2019/10/03 PHP
laravel通用化的CURD的实现
2019/12/13 PHP
jquery 实现的全选和反选
2009/04/15 Javascript
$.each遍历对象、数组的属性值并进行处理
2014/07/18 Javascript
详解javascript中的事件处理
2015/11/06 Javascript
初步了解javascript面向对象
2015/11/09 Javascript
jquery表单插件Autotab使用方法详解
2016/06/24 Javascript
jQuery制作网页版选项卡
2016/07/28 Javascript
setTimeout函数的神奇使用
2017/02/26 Javascript
基于JQuery和原生JavaScript实现网页定位导航特效
2017/04/03 jQuery
javascript实现循环广告条效果
2017/12/12 Javascript
vue获取元素宽、高、距离左边距离,右,上距离等还有XY坐标轴的方法
2018/09/05 Javascript
Angular使用Restful的增删改
2018/12/28 Javascript
Vue render函数实战之实现tabs选项卡组件
2019/04/22 Javascript
vue表单验证之禁止input输入框输入空格
2020/12/03 Vue.js
[52:02]完美世界DOTA2联赛PWL S2 FTD.C vs SZ 第一场 11.27
2020/11/30 DOTA
简析Python的闭包和装饰器
2016/02/26 Python
Python 用Redis简单实现分布式爬虫的方法
2017/11/23 Python
Python实现基于二叉树存储结构的堆排序算法示例
2017/12/08 Python
python使用梯度下降和牛顿法寻找Rosenbrock函数最小值实例
2020/04/02 Python
纯CSS3编写的的精美动画进度条(无flash/无图像/无脚本/附源码)
2013/01/07 HTML / CSS
BrandAlley英国:法国折扣奢侈品网上零售商
2017/07/03 全球购物
WebSphere 应用服务器都支持哪些认证
2013/12/26 面试题
大专毕业生简历的自我评价
2013/10/20 职场文书
巧克力蛋糕店创业计划书
2014/01/14 职场文书
驾驶员岗位职责
2014/01/29 职场文书
财务内勤岗位职责
2014/04/17 职场文书
节能宣传周活动总结
2014/05/08 职场文书
工作试用期自我评价
2015/03/10 职场文书
统计员岗位职责范本
2015/04/14 职场文书
2015年公务员工作总结
2015/04/24 职场文书
交通事故代理词范文
2015/05/23 职场文书
全陪导游词开场白
2015/05/29 职场文书
2015年小学远程教育工作总结
2015/07/28 职场文书
postgres之jsonb属性的使用操作
2021/06/23 PostgreSQL