当前位置: 首页 > news >正文

快速排序(Quick Sort)详解与图解

快速排序(Quick Sort)是一种**分治思想(Divide and Conquer)**的经典算法,也是面试与嵌入式开发中最常用的排序算法之一。
本文通过详细代码、逐步图解和运行示例,带你从零彻底理解快速排序。


一、快速排序的基本思想

快速排序的核心思想非常简洁:

取一个基准数(pivot)
把数组分成两边:左边比它小,右边比它大,
然后对两边继续递归排序。”

重复这个过程,直到每一段只剩一个元素,整个数组自然有序。


二、代码实现(Hoare 双指针分区法)

void quick_sort(int a[], int l, int r) {// 递归结束条件if (l >= r) return;// 定义两个指针int i = l - 1, j = r + 1;// 选择中间值为基准int pivot = a[(l + r) / 2];// 一次划分while (i < j) {do i++; while (a[i] < pivot);do j--; while (a[j] > pivot);if (i < j) {int temp = a[i];a[i] = a[j];a[j] = temp;}}// 递归左右两部分quick_sort(a, l, j);quick_sort(a, j + 1, r);
}

三、算法过程图解

示例数组:

[6, 1, 2, 7, 9, 3, 4, 5, 10, 8]


Step 1:第一次划分(pivot = 9)

     [6, 1, 2, 7, 9, 3, 4, 5, 10, 8]

pivot = 9 ↙----------------↘

  [6, 1, 2, 7, 8, 3, 4, 5] [10, 9]

左边都比 9 小,右边都比 9 大。


Step 2:第二次划分(左区 pivot = 7)

     [6, 1, 2, 7, 8, 3, 4, 5]

pivot = 7 ↙------------↘

     [6, 1, 2, 3, 4, 5] [8]


Step 3:第三次划分(左区 pivot = 3)

     [6, 1, 2, 3, 4, 5]

pivot = 3 ↙------↘

    [1, 2] [4, 5, 6]


Step 4:右区划分(pivot = 10)

[10, 9]
pivot = 10
↙----↘
[9]   []


四、递归返回与最终排序结果

当所有区间长度缩小为 1 时,递归开始返回:

[1, 2] + [3] + [4, 5, 6] = [1, 2, 3, 4, 5, 6]

[1, 2, 3, 4, 5, 6] + [7] + [8] = [1, 2, 3, 4, 5, 6, 7, 8]

[1, 2, 3, 4, 5, 6, 7, 8] + [9] + [10] = ✅ [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]

最终结果:

[1, 2, 3, 4, 5, 6, 7, 8, 9, 10]

http://www.dtcms.com/a/536626.html

相关文章:

  • NB-IOT(4) :从媒体接入到数据传输的全链路解析
  • 如何使用Advanced Installer打包C#程序生成安装程序
  • 做网站的开题报告怎么写云服务器
  • 产品公司网站建设方案模板美味的树莓派wordpress
  • Word VBA中的Collapse方法详解
  • 介绍一下Spring Cloud LoadBalancer
  • 写作网站排名南京专业网站优化公司
  • 今日印度股市最新行情与实时走势分析(截至2025年10月27日)
  • KingbaseES数据库操作指南(2):SQL语法从入门到精通
  • 介绍一个不错的新闻源汇总开源Github项目 BestBlogs
  • 第3章 运行时数据区概述及线程
  • 深入理解C语言函数栈帧:程序运行的底层密码
  • 谷歌网站怎么做外链站长工具端口查询
  • FPGA DDR3实战(十):基于DDR3的高速故障录播系统(二)—— 数据流转换与时钟域设计
  • 运维蓝图 用多工具组合把 iOS 混淆变成可复用的工程能力(iOS 混淆 IPA 加固 )
  • Caddyfile:用最简单的方式配置最现代的 Web 服务器
  • 昆明森贤网站建设国外h5网站模板下载
  • 机器人信息|基于Springboot的机器人门户展示系统设计与实现(源码+数据库+文档)
  • 上海网站空间租用自己做网站自己做推广教程视频教程
  • 《Cesium进阶教程:Shader与三维GIS可视化实战》
  • 从零开始打造Android桌面Launcher应用:原理剖析与完整实现
  • asp.net企业网站源码网站jquery上传源代码
  • 广州企业网站模板建站龙岩天宫山住宿
  • 单例模式:设计模式中的“独一无二“之道
  • CV论文速递:覆盖3D视觉与场景重建、视觉-语言模型(VLM)与多模态生成等方向!(10.20-10.24)
  • BERT 原理解析:从 Transformer 到双向语义理解
  • 土地流转网站建设项目网站制作步骤是什么
  • 网站开发 教学大纲wordpress一键仿站
  • 网站打开乱码app如何做
  • 【LabelImg】