0

0

C++里的std::sort底层是用什么算法实现的?(内省排序Introsort结合快排与堆排)

尼克

尼克

发布时间:2026-01-18 12:07:21

|

602人浏览过

|

来源于php中文网

原创

c++kquote>std::sort采用内省排序(introsort),以quicksort为基线,递归过深时切heapsort,小数组用insertionsort优化,兼顾平均性能与O(n log n)最坏复杂度。

c++里的std::sort底层是用什么算法实现的?(内省排序introsort结合快排与堆排)

std::sort 用的是内省排序(introsort),不是纯快排

标准库实现不强制规定算法,但所有主流实现(GCC libstdc++、LLVM libc++、MSVC STL)都采用 introsort:它以 quicksort 为基线,在递归深度超限时切换到 heapsort,最后对小数组用 insertionsort 优化。这种组合是为了同时保证平均性能和最坏情况的 O(n log n) 时间界。

为什么不用纯快排?——最坏情况太危险

quicksort 在 pivot 选得极差时会退化到 O(n²),比如已排序数组 + 固定取首/尾元素作 pivot。真实场景中,恶意输入或特定数据分布可能触发该路径。而 introsort 通过限制最大递归深度为 2 × floor(log₂ n) 来检测异常,一旦超限就切到 heapsort,彻底规避退化。

实际实现里还混了插入排序和分支预测优化

主流实现会在子数组长度 ≤ 某个阈值(如 GCC 是 16)时直接调用 insertionsort,因为小数组上它的常数项更优;同时,部分实现(如 libc++)还会在 partition 阶段用 __median_of_3 选 pivot,并加入分支预测提示(__builtin_expect)减少 pipeline stall。

  • std::sort 不稳定,若需稳定排序请用 std::stable_sort
  • 自定义比较函数必须满足严格弱序(strict weak ordering),否则行为未定义
  • 迭代器必须是随机访问迭代器(RandomAccessIterator),std::list::sort 是特例,用的是归并

可以验证 introsort 行为的简单方式

虽然标准不暴露内部机制,但你可以构造一个深度可控的递归计数器 + 自定义 comparator 观察退化防护逻辑(注意:仅用于理解,勿在生产环境依赖):

AI at Meta
AI at Meta

Facebook 旗下的AI研究平台

下载

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

struct counting_comp {
    mutable int depth = 0;
    bool operator()(int a, int b) const {
        ++depth;
        return a < b;
    }
};

配合 std::vector 构造极端有序数据并反复调用 std::sort,你会发现 depth 增长被有效抑制——这就是 introsort 的深度保护在起作用。

真正要注意的是:别假设 pivot 策略或阈值,这些是实现细节;重点确保你的 Compare 对象无副作用、满足可传递性,否则连 O(n log n) 都无法保障。

相关专题

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

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

386

2023.09.04

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

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

390

2023.07.18

堆和栈区别
堆和栈区别

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

572

2023.08.10

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

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

402

2023.08.14

高德地图升级方法汇总
高德地图升级方法汇总

本专题整合了高德地图升级相关教程,阅读专题下面的文章了解更多详细内容。

43

2026.01.16

全民K歌得高分教程大全
全民K歌得高分教程大全

本专题整合了全民K歌得高分技巧汇总,阅读专题下面的文章了解更多详细内容。

84

2026.01.16

C++ 单元测试与代码质量保障
C++ 单元测试与代码质量保障

本专题系统讲解 C++ 在单元测试与代码质量保障方面的实战方法,包括测试驱动开发理念、Google Test/Google Mock 的使用、测试用例设计、边界条件验证、持续集成中的自动化测试流程,以及常见代码质量问题的发现与修复。通过工程化示例,帮助开发者建立 可测试、可维护、高质量的 C++ 项目体系。

24

2026.01.16

java数据库连接教程大全
java数据库连接教程大全

本专题整合了java数据库连接相关教程,阅读专题下面的文章了解更多详细内容。

35

2026.01.15

Java音频处理教程汇总
Java音频处理教程汇总

本专题整合了java音频处理教程大全,阅读专题下面的文章了解更多详细内容。

16

2026.01.15

热门下载

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

精品课程

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

共61课时 | 3.5万人学习

PostgreSQL 教程
PostgreSQL 教程

共48课时 | 7.3万人学习

好课诞生记
好课诞生记

共20课时 | 6.1万人学习

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

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