0

0

C++怎么实现快速排序_C++算法优化教程【经典】

尼克

尼克

发布时间:2026-03-05 12:34:02

|

551人浏览过

|

来源于php中文网

原创

std::sort比手写快排更值得用,因其采用introsort(快排+堆排+插入排序),性能更稳定且高度优化;手写易出错,如比较函数不满足严格弱序会导致乱序或报错。

c++怎么实现快速排序_c++算法优化教程【经典】

std::sort 为什么比手写快排更值得用

绝大多数场景下,std::sort 就是你要的“快速排序”,它不一定是纯快排(实际是 introsort:快排 + 堆排 + 插入排序混合),但平均和最坏性能都更稳,且经过高度优化。自己实现 quick_sort 除非练手或有特殊约束(比如栈空间受限、必须确定性行为),否则纯属增加 bug 风险。

常见错误现象:std::sort 报错 invalid comparator,或排序结果乱序——大概率是自定义比较函数没满足严格弱序(比如用了 而不是 <code>)。

  • 使用场景:对 std::vectorstd::array、C 风格数组排序时,直接传迭代器即可
  • 参数差异:第三个参数必须是可调用对象,且返回 bool;不能捕获局部变量后忘记声明为 mutable(若需修改捕获值)
  • 性能影响:std::sort 对小数组自动切到插入排序,对递归过深自动切到堆排,避免 O(n²) 退化
std::vector<int> v = {3, 1, 4, 1, 5};
std::sort(v.begin(), v.end()); // 升序
std::sort(v.begin(), v.end(), std::greater<int>{}); // 降序

手写快排时 pivot 选错就全崩了

选 pivot 不是“随便挑一个”,而是决定是否触发最坏复杂度的关键。用 v[0]v[size-1] 在已排序/逆序数据上会稳定退化成 O(n²)。

容易踩的坑:partition 边界写错导致越界或死循环,尤其在处理重复元素多的数组(如全是 5)时,while (v[i] 这类条件极易卡住。

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

Bardeen AI
Bardeen AI

使用AI自动执行人工任务

下载
  • 推荐做法:用三数取中(v[0]v[mid]v[end] 中位数)做 pivot,再交换到末尾
  • 必须检查分区后左右段长度,空段或单元素段直接 return,避免无意义递归
  • 递归前先处理较短段,再用循环处理较长段(尾递归优化),能显著压低栈深度
int partition(std::vector<int>& v, int l, int r) {
    int mid = l + (r - l) / 2;
    if (v[mid] < v[l]) std::swap(v[l], v[mid]);
    if (v[r] < v[l]) std::swap(v[l], v[r]);
    if (v[r] < v[mid]) std::swap(v[mid], v[r]);
    std::swap(v[mid], v[r]); // pivot 放末尾
    int pivot = v[r];
    int i = l;
    for (int j = l; j < r; ++j) {
        if (v[j] < pivot) {
            std::swap(v[i++], v[j]);
        }
    }
    std::swap(v[i], v[r]);
    return i;
}

std::sort 不能排序 const 容器或只读数据

这是编译期就报错的问题:std::sort 要求迭代器是可写的(RandomAccessIterator 且 value_type 可赋值)。对 const std::vector<int></int> 或字面量数组(如 const int a[] = {1,2,3})直接调用会触发模板推导失败或 assignment 操作符不可用。

使用场景:想排序一串常量数据,又不想改原始定义?别硬套 std::sort

  • 方案一:复制到非 const 容器再排,如 std::vector<int> tmp{std::begin(a), std::end(a)}</int>
  • 方案二:用 std::array 替代 C 数组,它支持拷贝构造,且 std::sort 可作用于其迭代器
  • 注意:std::string_viewstd::span<const t></const> 同样不可排,必须转成可写视图或复制

迭代器失效和移动语义影响排序结果

对含指针、智能指针或自定义类型的容器排序时,std::sort 内部交换元素靠的是 std::swap,而 swap 行为取决于类型是否支持移动。如果类没正确定义移动构造/赋值,或者禁用了移动(如显式删除了移动操作),就会退回到拷贝,可能引发意外副作用(比如拷贝时触发资源重复申请)。

常见错误现象:排序后容器里某些对象状态异常(如 std::unique_ptr 变成空,或自定义类里缓存索引错乱)。

  • 检查类型是否可移动:std::is_move_constructible_v<t></t>std::is_move_assignable_v<t></t>
  • 对含裸指针的结构体,排序后原指针值不变,但所指内存顺序变了——别假设指针数组排序后指向关系仍成立
  • std::stable_sort 替代时要注意:它不保证用快排,底层可能是归并,内存开销更大

标准库的排序已经足够好,真正要花时间的地方不是“怎么写快排”,而是理解你的数据分布、内存访问模式和类型语义——这些才决定最终性能上限。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

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

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

408

2023.09.04

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

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

434

2023.07.18

堆和栈区别
堆和栈区别

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

600

2023.08.10

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

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

434

2023.07.18

堆和栈区别
堆和栈区别

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

600

2023.08.10

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

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

487

2023.08.14

Rust内存安全机制与所有权模型深度实践
Rust内存安全机制与所有权模型深度实践

本专题围绕 Rust 语言核心特性展开,深入讲解所有权机制、借用规则、生命周期管理以及智能指针等关键概念。通过系统级开发案例,分析内存安全保障原理与零成本抽象优势,并结合并发场景讲解 Send 与 Sync 特性实现机制。帮助开发者真正理解 Rust 的设计哲学,掌握在高性能与安全性并重场景中的工程实践能力。

2

2026.03.05

PHP高性能API设计与Laravel服务架构实践
PHP高性能API设计与Laravel服务架构实践

本专题围绕 PHP 在现代 Web 后端开发中的高性能实践展开,重点讲解基于 Laravel 框架构建可扩展 API 服务的核心方法。内容涵盖路由与中间件机制、服务容器与依赖注入、接口版本管理、缓存策略设计以及队列异步处理方案。同时结合高并发场景,深入分析性能瓶颈定位与优化思路,帮助开发者构建稳定、高效、易维护的 PHP 后端服务体系。

58

2026.03.04

AI安装教程大全
AI安装教程大全

2026最全AI工具安装教程专题:包含各版本AI绘图、AI视频、智能办公软件的本地化部署手册。全篇零基础友好,附带最新模型下载地址、一键安装脚本及常见报错修复方案。每日更新,收藏这一篇就够了,让AI安装不再报错!

31

2026.03.04

热门下载

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

精品课程

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

共94课时 | 10.7万人学习

C 教程
C 教程

共75课时 | 5.2万人学习

C++教程
C++教程

共115课时 | 20.6万人学习

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

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