转自:https://www.cnblogs.com/AlwinXu/p/5424905.html

快速排序(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-完成的时候,此时令循环结束)。

时间复杂度:O(nlgn)

#QuickSort by Alvindef QuickSort(myList,start,end):#判断low是否小于high,如果为false,直接返回 if start < end: i,j = start,end #设置基准数 base = myList[i] while i < j: #如果列表后边的数,比基准数大或相等,则前移一位直到有比基准数小的数出现 while (i < j) and (myList[j] >= base): j = j - 1 #如找到,则把第j个元素赋值给第个元素i,此时表中i,j个元素相等 myList[i] = myList[j] #同样的方式比较前半区 while (i < j) and (myList[i] <= base): i = i + 1 myList[j] = myList[i] #做完第一轮比较之后,列表被分成了两个半区,并且i=j,需要将这个数设置回base myList[i] = base #递归前后半区 QuickSort(myList, start, i - 1) QuickSort(myList, j + 1, end) return myList myList = [49,38,65,97,76,13,27,49] print("Quick Sort: ") QuickSort(myList,0,len(myList)-1) print(myList)

转载于:https://www.cnblogs.com/fengff/p/9213738.html

Python排序算法之快速排序相关推荐

  1. Python排序算法(二) 快速排序、希尔排序、归并排序

    这篇文章有的排序算法是:快速排序.希尔排序.归并排序. 快速排序 ''' 快速排序 '''def quick_sort(aList, first, last):if first >= last: ...

  2. Python排序算法总结

    Python排序算法总结 递归 在正式讲算法之前,先介绍一下递归.递归是一种解决问题的思路. 特点 调用自身 必须有一个明确的结束条件,比如if... 递归的两个阶段: 递推(压栈):到某个阶段,该阶 ...

  3. 带你掌握4种Python 排序算法

    摘要:在编程里,排序是一个重要算法,它可以帮助我们更快.更容易地定位数据.在这篇文章中,我们将使用排序算法分类器对我们的数组进行排序,了解它们是如何工作的. 本文分享自华为云社区<Python ...

  4. python排序算法——插入排序

    python排序算法--插入排序 文章目录 python排序算法--插入排序 一.前言 二.描述 三.代码实现 总结 一.前言 相关知识来自<python算法设计与分析>.初级排序算法是指 ...

  5. python排序算法

    Python中有许多不同的排序算法,其中包括: 冒泡排序 选择排序 插入排序 快速排序 归并排序 堆排序 除了这些常见的排序算法,还有其他一些不太常见的算法,例如希尔排序.计数排序等. 在选择排序算法 ...

  6. 十大排序算法之快速排序(两种方法)

    十大排序算法之快速排序 本文采用Java书写选择排序,其他语言类似可以借鉴着写 思想:在待排序序列中选择一个分割元素,将待排序序列中所有比分割元素关键字小的元素移动到分割元素左侧位置:将待排序序列中所 ...

  7. 排序算法之----快速排序(快速上手快速排序)

    排序算法之----快速排序(快速上手快速排序) 何为快速排序算法? 快速排序的基本思想又是什么? 其实很简单: 快速排序的基本思想是 1.先从数列中取出一个数作为基准数(这里我们的算法里面取数组最右边 ...

  8. php1到5000排序,常用的排序算法(一)--快速排序(PHP实现)

    常用的排序算法系列 快速排序 假设当前需要从小到大进行排序,快速排序的核心思路是,从当前数组中,找到一个元素作为基准比较值(key),分别从两个方向进行比较.从后往前找,比key小元素放在数组前面.然 ...

  9. Python排序算法[二]:测试数据的迷雾散去

    算法试验中不仅仅要尝试使用不同的写法,更要注意测试所用数据的规律性,它们都会直接影响测试结果. 在上一篇文章<Python 排序算法[一]:令你茅塞顿开,却又匪夷所思>中我们学习了排序算法 ...

最新文章

  1. python 模拟HTTP服务端
  2. 在DWR中实现直接获取一个JAVA类的返回值的两种方法
  3. 白话Elasticsearch51-深入聚合数据分析之text field聚合以及fielddata原理
  4. 【机器学习】特征预处理
  5. Effective Java之静态工厂代替构造器(一)
  6. python里it n_Python3 round(x [,n]) 函数
  7. 为什么在JavaScript中0.1+0.2不等于0.3?
  8. ChaiNext:比特币打穿4.2万美元,市场多空胶着
  9. php本地如何开启websocket遇到的坑
  10. Android input touchpanel驱动流程
  11. Js实现实时显示系统时间(获取当前时间并显示)
  12. Faker最新仓库地址更新 4/6
  13. [面试经验]一汽大众旗下车联网公司摩斯智联面试记
  14. iOS虚拟支付被封,6个技巧帮你快速解决烦恼
  15. 计算机策略编辑器,组策略及组策略编辑器基础知识
  16. Django中app的model相互引用问题
  17. 柯尼卡美能达打印机无法使用ID打印
  18. 2022年,中国餐饮数字化进行到哪一步了?
  19. 免费手机号码归属地API查询接口
  20. Linux7配置team聚合链之主备模式

热门文章

  1. Linux 文件颜色含义
  2. SpringBoot JPA
  3. 怎样用C语言实现五子棋,C语言实现五子棋
  4. wordpress linux 目录,快速搭建WordPress(Linux)
  5. C++面试常见问题整理汇总(面试者必看哦!)
  6. js文件 import java类_实现JS脚本导入JAVA类包
  7. java中的wn是什么意思_wnJava--做简捷的互动社区网站
  8. android系统三防机,这才是真正给老人设计的智能手机:三防+安卓系统+超大音量,AGM H2...
  9. python 数据处理----读取txt 一列数据写入excel 文件
  10. 光端机使用过程中碰到的九大问题