news 2026/6/10 9:23:35

快速排序的基本思想是选择一个基准元素,通过partition函数将数组划分为两部分:一部分比基准小,另一部分比基准大,然后递归地对这两个子数组进行排序

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
快速排序的基本思想是选择一个基准元素,通过partition函数将数组划分为两部分:一部分比基准小,另一部分比基准大,然后递归地对这两个子数组进行排序

快速排序的基本思想是选择一个基准元素,通过partition函数将数组划分为两部分:一部分比基准小,另一部分比基准大,然后递归地对这两个子数组进行排序。

defquick_sort(arr):iflen(arr)<=1:returnarrelse:pivot=arr[len(arr)//2]# 选择中间元素作为基准left=[xforxinarrifx<pivot]middle=[xforxinarrifx==pivot]right=[xforxinarrifx>pivot]returnquick_sort(left)+middle+quick_sort(right)

其平均时间复杂度为 $ O(n \log n) $,是同量级中性能最优的排序算法之一;最坏情况下(如数组已有序),时间复杂度退化为 $ O(n^2) $。快速排序是一种不稳定排序,相同元素的相对位置可能在排序过程中发生改变。

堆排序则是基于堆这种数据结构的排序方法。堆是一个完全二叉树的数组表示,分为大根堆和小根堆:

  • 大根堆:每个父节点的值 ≥ 其子节点,堆顶为最大值;
  • 小根堆:每个父节点的值 ≤ 其子节点,堆顶为最小值。

堆排序的核心步骤包括:

  1. 构建初始堆(以大根堆为例,将最大值置于堆顶);
  2. 将堆顶元素与末尾元素交换,输出该最大值;
  3. 调整剩余元素使其重新满足堆的性质;
  4. 重复上述过程直到所有元素有序。

堆排序的时间复杂度始终为 $ O(n \log n) $,空间复杂度为 $ O(1) $,属于原地排序,但也是不稳定排序
快速排序的原地版本通过在原数组上进行元素交换,并使用双指针技术来划分区间,避免创建额外的数组(如left,middle,right列表),从而将空间复杂度从 $ O(n) $ 优化到 $ O(\log n) $(仅用于递归调用栈)。

✅ 原地快排实现逻辑:

  1. 选择一个基准元素(pivot),通常选区间的第一个、最后一个或中间元素;
  2. 使用两个指针ij,在[low, high]范围内进行划分:
    • i从左向右找大于等于 pivot 的元素;
    • j从右向左找小于等于 pivot 的元素;
    • i < j,则交换arr[i]arr[j]
  3. 最终将基准元素放到正确位置(与ij重合的位置交换);
  4. 递归对左右两部分排序。

🧩 Python 实现代码(原地快排):

defquick_sort_inplace(arr,low=0,high=None):ifhighisNone:high=len(arr)-1iflow<high:# 分区操作,返回基准元素的最终位置pivot_index=partition(arr,low,high)# 递归排序基准左侧和右侧quick_sort_inplace(arr,low,pivot_index-1)quick_sort_inplace(arr,pivot_index+1,high)defpartition(arr,low,high):pivot=arr[low]# 选择第一个元素作为基准i=low+1# 左指针,从第二个元素开始j=high# 右指针,指向末尾done=Falsewhilenotdone:# 向右移动 i,直到找到大于等于 pivot 的元素whilei<=jandarr[i]<=pivot:i+=1# 向左移动 j,直到找到小于等于 pivot 的元素whilei<=jandarr[j]>=pivot:j-=1# 如果 i < j,则交换 arr[i] 和 arr[j]ifi<j:arr[i],arr[j]=arr[j],arr[i]else:done=True# 将基准元素放到正确位置arr[low],arr[j]=arr[j],arr[low]returnj# 返回基准位置# 示例使用arr=[3,6,8,10,1,2,1]quick_sort_inplace(arr)print(arr)# 输出: [1, 1, 2, 3, 6, 8, 10]

⚖️ 优缺点分析:

  • 优点
    • 空间复杂度仅为 $ O(\log n) $(递归深度);
    • 原地排序,节省内存;
    • 实际运行速度快,缓存友好。
  • 缺点
    • 不稳定排序(相同值可能改变顺序);
    • 最坏情况仍为 $ O(n^2) $(可通过随机化 pivot 改善)。

💡 提示:可进一步优化为“三路快排”或“随机选取 pivot”来应对重复元素多或有序输入的情况。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/10 5:59:16

谷歌镜像网站访问困难?改用国内源下载腾讯混元OCR更稳定

谷歌镜像网站访问困难&#xff1f;改用国内源下载腾讯混元OCR更稳定 在企业文档自动化、智能审批系统和跨境电商业务中&#xff0c;OCR 已不再是简单的“图像转文字”工具&#xff0c;而是承载着结构化信息抽取、语义理解与流程自动化的关键能力。然而&#xff0c;一个现实问题…

作者头像 李华
网站建设 2026/5/25 14:37:12

政务大厅智能化:居民办事材料现场扫描即时结构化输出

政务大厅智能化&#xff1a;居民办事材料现场扫描即时结构化输出 在各地政务大厅里&#xff0c;一个看似简单却长期困扰服务效率的场景反复上演&#xff1a;居民排长队提交身份证、户口本、营业执照等纸质材料&#xff0c;窗口人员低头手动录入信息&#xff0c;一边翻证件一边…

作者头像 李华
网站建设 2026/6/10 12:56:45

音乐节现场互动:观众手举牌OCR识别弹出定制化数字纪念卡

音乐节现场互动&#xff1a;观众手举牌OCR识别弹出定制化数字纪念卡 在一场万人齐聚的音乐节现场&#xff0c;舞台灯光闪烁&#xff0c;人潮涌动。某个瞬间&#xff0c;成千上万的观众同时举起手中的纸板&#xff0c;上面写着五花八门的手写标语——“我爱周杰伦&#xff01;”…

作者头像 李华
网站建设 2026/6/10 12:56:57

农业物联网应用:农药包装说明OCR识别辅助安全用药指导

农业物联网应用&#xff1a;农药包装说明OCR识别辅助安全用药指导 在广袤的农田里&#xff0c;一位老农拿着一瓶刚买的农药&#xff0c;眯着眼睛反复对照说明书上的小字——“每亩用15毫升&#xff1f;还是10毫升&#xff1f;”阳光刺眼&#xff0c;标签反光&#xff0c;加上密…

作者头像 李华
网站建设 2026/6/10 11:13:30

房产中介资料整理:房源信息卡片OCR录入客户管理系统

房产中介资料整理&#xff1a;房源信息卡片OCR录入客户管理系统 在房产中介的日常运营中&#xff0c;每天都有大量纸质或拍照形式的房源信息卡片涌入——小区门口张贴的售房启事、门店白板上手写的最新挂牌、经纪人现场拍摄的户型说明。这些信息承载着地址、面积、价格、装修等…

作者头像 李华
网站建设 2026/6/10 11:10:36

学了这么多年编程,为什么最后还是绕不开 C++?

> **从“嫌它难”到“必须懂”&#xff0c;C 为什么始终站在技术金字塔的上层**---## 一、几乎每个程序员&#xff0c;都会经历一次“逃离 C”如果你问一个程序员对 C 的第一印象&#xff0c;答案大概率是&#xff1a; **难、复杂、容易出错、不友好。**很多人在刚入门时接触…

作者头像 李华