此为视频 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

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

被折叠的 条评论
为什么被折叠?



