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脚本实现格式化css文件
Apr 08 Python
Python处理字符串之isspace()方法的使用
May 19 Python
python3之微信文章爬虫实例讲解
Jul 12 Python
python编程测试电脑开启最大线程数实例代码
Feb 09 Python
python实现扫描日志关键字的示例
Apr 28 Python
详解python3中zipfile模块用法
Jun 18 Python
python实现AES加密和解密
Mar 27 Python
自适应线性神经网络Adaline的python实现详解
Sep 30 Python
python判断单向链表是否包括环,若包含则计算环入口的节点实例分析
Oct 23 Python
Python基于进程池实现多进程过程解析
Apr 30 Python
Django如何批量创建Model
Sep 01 Python
Python Matplotlib库实现画局部图
Nov 17 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
提取HTML标签
2006/10/09 PHP
PHP IN_ARRAY 函数使用注意事项
2010/07/24 PHP
PHP中调用ASP.NET的WebService的代码
2011/04/22 PHP
php从csv文件读取数据并输出到网页的方法
2015/03/14 PHP
PHP中两个float(浮点数)比较实例分析
2015/09/27 PHP
Yii Framework框架使用PHPExcel组件的方法示例
2019/07/24 PHP
javascript知识点收藏
2007/02/22 Javascript
论坛里点击别人帖子下面的回复,回复标题变成“回复 24# 的帖子”
2009/06/14 Javascript
基于jquery的多彩百分比 动态进度条 投票效果显示效果实现代码
2011/08/28 Javascript
枚举的实现求得1-1000所有出现1的数字并计算出现1的个数
2013/09/10 Javascript
JS实现点击链接取消跳转效果的方法
2014/01/24 Javascript
学习JavaScript设计模式之责任链模式
2016/01/18 Javascript
jQuery弹出层后禁用底部滚动条(移动端关闭回到原位置)
2016/08/29 Javascript
Node.js环境下Koa2添加travis ci持续集成工具的方法
2017/06/19 Javascript
Vue.js弹出模态框组件开发的示例代码
2017/07/26 Javascript
利用nginx + node在阿里云部署https的步骤详解
2017/12/19 Javascript
对angularJs中自定义指令replace的属性详解
2018/10/09 Javascript
JS实现根据详细地址获取经纬度功能示例
2019/04/16 Javascript
Vue 实现分页与输入框关键字筛选功能
2020/01/02 Javascript
angular组件间通讯的实现方法示例
2020/05/07 Javascript
[56:56]VG vs LGD 2019国际邀请赛淘汰赛 胜者组 BO3 第一场 8.22
2019/09/05 DOTA
[01:02:32]DOTA2-DPC中国联赛 正赛 iG vs PSG.LGD BO3 第二场 2月26日
2021/03/11 DOTA
python下如何查询CS反恐精英的服务器信息
2017/01/17 Python
Python爬虫番外篇之Cookie和Session详解
2017/12/27 Python
Python编程pygame模块实现移动的小车示例代码
2018/01/03 Python
python3获取两个日期之间所有日期,以及比较大小的实例
2018/04/08 Python
Python设计模式之简单工厂模式实例详解
2019/01/22 Python
python爬虫模拟浏览器访问-User-Agent过程解析
2019/12/28 Python
通过实例了解Python str()和repr()的区别
2020/01/17 Python
Python关于拓扑排序知识点讲解
2021/01/04 Python
函授大学生自我鉴定
2014/02/05 职场文书
《月光启蒙》教学反思
2014/03/01 职场文书
销售职业生涯规划范文
2014/03/14 职场文书
幼儿园教师自荐书
2015/03/06 职场文书
公司禁烟通知
2015/04/23 职场文书
浅谈JS和Nodejs中的事件驱动
2021/05/05 NodeJs