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检测QQ在线状态的方法
May 09 Python
python简单实现基数排序算法
May 16 Python
详解supervisor使用教程
Nov 21 Python
tensorflow识别自己手写数字
Mar 14 Python
python Flask 装饰器顺序问题解决
Aug 08 Python
python找出完数的方法
Nov 12 Python
对Python 多线程统计所有csv文件的行数方法详解
Feb 12 Python
python代码打印100-999之间的回文数示例
Nov 24 Python
Python Des加密解密如何实现软件注册码机器码
Jan 08 Python
Python龙贝格法求积分实例
Feb 29 Python
matplotlib 对坐标的控制,加图例注释的操作
Apr 17 Python
python中实现栈的三种方法
Dec 19 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
phpMyAdmin2.11.6安装配置方法
2008/08/24 PHP
PHP提取字符串中的图片地址[正则表达式]
2011/11/12 PHP
PHP 读取大文件并显示的简单实例(推荐)
2016/08/12 PHP
PHP树形结构tree类用法示例
2019/02/01 PHP
jquery随机展示头像代码
2011/12/21 Javascript
jQuery Animation实现CSS3动画示例介绍
2013/08/14 Javascript
jquery跟js初始化加载的多种方法及区别介绍
2014/04/02 Javascript
node.js中的fs.fchmod方法使用说明
2014/12/16 Javascript
由ReactJS的Hello world说开来
2015/07/02 Javascript
轻松实现jquery手风琴效果
2016/01/14 Javascript
jQuery Mobile 触摸事件实例
2016/06/04 Javascript
JS+Canvas实现的俄罗斯方块游戏完整实例
2016/12/12 Javascript
AngularJS学习第二篇 AngularJS依赖注入
2017/02/13 Javascript
ES6中Proxy代理用法实例浅析
2017/04/06 Javascript
jQuery事件_动力节点Java学院整理
2017/07/05 jQuery
在 Typescript 中使用可被复用的 Vue Mixin功能
2018/04/17 Javascript
vue input 输入校验字母数字组合且长度小于30的实现代码
2018/05/16 Javascript
vue指令只能输入正数并且只能输入一个小数点的方法
2018/06/08 Javascript
详解如何给React-Router添加路由页面切换时的过渡动画
2019/04/25 Javascript
Element Breadcrumb 面包屑的使用方法
2020/07/26 Javascript
JavaScript构造函数原理及实现流程解析
2020/11/19 Javascript
使用python调用浏览器并打开一个网址的例子
2014/06/05 Python
python脚本实现查找webshell的方法
2014/07/31 Python
python笔记:mysql、redis操作方法
2017/06/28 Python
浅谈python装饰器探究与参数的领取
2017/12/01 Python
Python Datetime模块和Calendar模块用法实例分析
2019/04/15 Python
python GUI实现小球满屏乱跑效果
2019/05/09 Python
使用CSS实现弹性视频html5案例实践
2012/12/26 HTML / CSS
跑鞋、网球鞋、网球拍、服装及装备:Holabird Sports
2016/09/19 全球购物
阿迪达斯法国官方网站:adidas法国
2018/03/20 全球购物
施工资料员的岗位职责
2013/12/22 职场文书
大学生咖啡店创业计划书
2014/01/21 职场文书
个人授权委托书
2014/04/03 职场文书
教师年终个人总结
2015/02/11 职场文书
慈善献爱心倡议书
2015/04/27 职场文书
使用python绘制横竖条形图
2022/04/21 Python