python排序之快速排序
快速排序
快速排序是比较常用的一种排序方式,通过递归的方法进行排序
首先使用递归方式我们先要解决两个问题:1找到基准条件 2找到递归条件
基线条件为数组为空或只包含一个元素。在这种情况下,只需原样返回数组——根本就不用排序
那么这样我们就会把数组长度小于2的定位我们基准条件
然后我们会将剩余数组进行分区,分为较大区域和较小区域,假设大区域和小区域都是无需排序的有序数组,那么我们将小区域加上基准加上大区域,就是最后我们排序后所需要的数组
那么我只需要把大区域和小区域进行递归直到大区域和小区域都完成排序
代码实现:
1 2 3 4 5 6 7 8 9 10 11 12 13 | def quickSort(array): larger = list () smaller = list () if len (array) < 2 : return array else : standard = array[ 0 ] for i in array[ 1 :]: if i > standard: larger.append(i) else : smaller.append(i) return quickSort(smaller) + [standard] + quickSort(larger) |
作者: yetangjian
出处: https://www.cnblogs.com/yetangjian/p/16273037.html
关于作者: yetangjian
本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出, 原文链接 如有问题, 可邮件(yetangjian@outlook.com)咨询.
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· 从HTTP原因短语缺失研究HTTP/2和HTTP/3的设计差异
· 三行代码完成国际化适配,妙~啊~