c++ STL sort的实现

C++ STL的sort函数采用快速排序算法,并进行了优化,防止在处理有序数组时退化为n²复杂度。它将数据分为16块进行有序处理,结合插入排序优势。当遇到特定情况导致复杂度超过2*logn时,会切换到堆排序以保持nlogn的时间复杂度。此外,sort还应用了单边递归法和无监督快速排序等技术提高效率。

此为视频 c++ STL sort的实现 的观后感https://www.bilibili.com/video/BV1Wo4y1m7nC?spm_id_from=333.337.search-card.all.click1.sort的内部实现是快排。一般快排的时间复杂度是nlogn,且最差情况会退化成n²。(什么是快排(补坑)),但是c++里STL里的sort就做了很多优化,避免了sort里退化成n²的情况,在保证一个稳定的复杂度的情况下尽可能地快。

2.STL中sort的实现(?)

template<class _RandomAccessIter>
inline void sort(_RandomAccessIter __first, _RandomAccessIter __last)
{
    __STL_REQUIRES(_RandomAccessIter, _Mutable_RandomAccessIterator);
    __STL_REQUIRES(typename iterator_traits<_RandomAcc
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值