0

0

C++怎么实现一个快速排序算法_C++经典排序算法与QuickSort代码详解

冰火之心

冰火之心

发布时间:2025-11-21 17:51:06

|

926人浏览过

|

来源于php中文网

原创

快速排序采用分治策略,通过分区操作将数组分为两部分并递归排序。选择基准元素后,用双指针法重排数组,使左侧元素小于等于基准,右侧大于基准,基准置于正确位置。常用Lomuto分区方案以末尾元素为基准,通过交换实现分区,返回基准位置供递归使用。完整代码包含partition和quickSort函数,主函数演示了排序过程。优化方法包括随机化基准、三数取中、小数组改用插入排序及尾递归优化,提升性能与稳定性。C++标准库的std::sort结合快排、堆排和插排,适应多种数据场景。

c++怎么实现一个快速排序算法_c++经典排序算法与quicksort代码详解

快速排序是一种高效的排序算法,采用分治策略来把一个序列分成两个子序列。它的平均时间复杂度为 O(n log n),在实际应用中表现优秀,是 C++ 中常用的排序方法之一。下面详细介绍快速排序的实现原理和完整代码。

快速排序的基本思想

快速排序的核心是“分区”(partition)操作。从数组中选择一个基准元素(pivot),然后将数组中小于基准的元素移到左边,大于基准的元素移到右边,基准放在中间。这个过程完成后,基准元素的位置就是它在最终有序数组中的位置。接着对左右两个子数组递归执行相同的操作。

关键步骤包括:

  • 选择一个基准值(通常选首元素、尾元素或中间元素)
  • 重新排列数组,使小于基准的在左,大于的在右
  • 递归地对左右子数组进行快排

分区操作的实现方式

常见的分区方法是使用双指针法。以下是以最后一个元素为基准的 Lomuto 分区方案:

立即学习C++免费学习笔记(深入)”;

int partition(int arr[], int low, int high) {
    int pivot = arr[high]; // 基准
    int i = low - 1;       // 小于基准区域的边界
for (int j = low; j zuojiankuohaophpcn high; j++) {
    if (arr[j] zuojiankuohaophpcn= pivot) {
        i++;
        std::swap(arr[i], arr[j]);
    }
}
std::swap(arr[i + 1], arr[high]);
return i + 1;

}

小蓝本
小蓝本

ToB智能销售增长平台

下载

该函数返回基准元素的最终位置,便于后续递归调用划分区间。

完整的快速排序代码

结合递归函数,可以写出完整的快速排序实现:

#include 

void quickSort(int arr[], int low, int high) { if (low < high) { int pi = partition(arr, low, high); quickSort(arr, low, pi - 1); quickSort(arr, pi + 1, high); } }

// 使用示例 int main() { int arr[] = {10, 7, 8, 9, 1, 5}; int n = sizeof(arr) / sizeof(arr[0]);

quickSort(arr, 0, n - 1);

std::cout zuojiankuohaophpcnzuojiankuohaophpcn "Sorted array: ";
for (int i = 0; i zuojiankuohaophpcn n; ++i)
    std::cout zuojiankuohaophpcnzuojiankuohaophpcn arr[i] zuojiankuohaophpcnzuojiankuohaophpcn " ";
std::cout zuojiankuohaophpcnzuojiankuohaophpcn std::endl;

return 0;

}

优化建议与注意事项

虽然基础版本已经有效,但可以通过一些技巧提升性能:

  • 随机化基准:避免最坏情况(如已排序数组),可随机选择 pivot 并与末尾交换
  • 三数取中法:取首、中、尾三个元素的中位数作为基准
  • 小数组改用插入排序:当子数组长度小于 10 左右时切换为插入排序更高效
  • 尾递归优化:先处理较小区间,减少深度

基本上就这些。快速排序理解起来不难,但细节决定效率。掌握好分区逻辑和边界控制,就能写出稳定高效的版本。C++ 标准库中的 std::sort 实际上结合了快排、堆排序和插入排序(Introsort),以应对各种数据场景。

相关专题

更多
sort排序函数用法
sort排序函数用法

sort排序函数的用法:1、对列表进行排序,默认情况下,sort函数按升序排序,因此最终输出的结果是按从小到大的顺序排列的;2、对元组进行排序,默认情况下,sort函数按元素的大小进行排序,因此最终输出的结果是按从小到大的顺序排列的;3、对字典进行排序,由于字典是无序的,因此排序后的结果仍然是原来的字典,使用一个lambda表达式作为key参数的值,用于指定排序的依据。

384

2023.09.04

堆和栈的区别
堆和栈的区别

堆和栈的区别:1、内存分配方式不同;2、大小不同;3、数据访问方式不同;4、数据的生命周期。本专题为大家提供堆和栈的区别的相关的文章、下载、课程内容,供大家免费下载体验。

386

2023.07.18

堆和栈区别
堆和栈区别

堆(Heap)和栈(Stack)是计算机中两种常见的内存分配机制。它们在内存管理的方式、分配方式以及使用场景上有很大的区别。本文将详细介绍堆和栈的特点、区别以及各自的使用场景。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

568

2023.08.10

堆和栈的区别
堆和栈的区别

堆和栈的区别:1、内存分配方式不同;2、大小不同;3、数据访问方式不同;4、数据的生命周期。本专题为大家提供堆和栈的区别的相关的文章、下载、课程内容,供大家免费下载体验。

386

2023.07.18

堆和栈区别
堆和栈区别

堆(Heap)和栈(Stack)是计算机中两种常见的内存分配机制。它们在内存管理的方式、分配方式以及使用场景上有很大的区别。本文将详细介绍堆和栈的特点、区别以及各自的使用场景。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

568

2023.08.10

页面置换算法
页面置换算法

页面置换算法是操作系统中用来决定在内存中哪些页面应该被换出以便为新的页面提供空间的算法。本专题为大家提供页面置换算法的相关文章,大家可以免费体验。

398

2023.08.14

c++主流开发框架汇总
c++主流开发框架汇总

本专题整合了c++开发框架推荐,阅读专题下面的文章了解更多详细内容。

78

2026.01.09

c++框架学习教程汇总
c++框架学习教程汇总

本专题整合了c++框架学习教程汇总,阅读专题下面的文章了解更多详细内容。

45

2026.01.09

学python好用的网站推荐
学python好用的网站推荐

本专题整合了python学习教程汇总,阅读专题下面的文章了解更多详细内容。

118

2026.01.09

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
C# 教程
C# 教程

共94课时 | 6.5万人学习

C 教程
C 教程

共75课时 | 4万人学习

C++教程
C++教程

共115课时 | 11.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号