std::sort 排序算法本质

使用了内省排序(Introsort)

现代标准库实现中,std::sort 通常使用 内省排序(Introsort),它是一种混合排序算法,结合了以下三种算法的优点:

快速排序

作为主要算法,平均情况下效率很高 O ( n log ⁡ n ) O(n \log n) O(nlogn)

堆排序

当快速排序的递归深度过大(可能导致 O(n^2) ) 的最坏情况)时,切换到堆排序,保证最坏复杂度为 O ( n log ⁡ n ) O(n \log n) O(nlogn)

插入排序

对于小规模子序列(通常少于 16 个元素),使用插入排序,因为它在小数据集上更快。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值