《条目三十一:了解各种与排序有关的选择》

本文介绍了六种常用的排序算法,包括sort、partial_sort等,并详细解释了它们的特点及应用场景。此外,还提供了排序算法的选择建议,帮助读者理解不同算法之间的区别。

《条目三十一:了解各种与排序有关的选择》

  • 1.sort

    template<class _RanIt,class _Pr> inline
    void sort(const _RanIt _First, const _RanIt _Last, _Pr _Pred)
    全排序,整个容器排序。

  • 2.partial_sort

    template<class _RanIt,class _Pr> inline
    void partial_sort(_RanIt _First, _RanIt _Mid, _RanIt _Last, _Pr _Pred)
    设定排序区间大小,即设定局部全排序

  • 3.nth_element

    template<class _RanIt,class _Pr> inline
    void nth_element(_RanIt _First, _RanIt _Nth, _RanIt _Last, _Pr _Pred)
    选出符合条件的前n个,这n个不排序

  • 4.partition

    template<class _FwdIt,class _Pr> inline
    _FwdIt partition(_FwdIt _First, const _FwdIt _Last, _Pr _Pred)
    对整个容器分区,根据符合的条件分区。返回的迭代器指向第一个不符合条件的元素。

1, 2, 3, 4都要求是随机迭代器,所以只能应用在vector,string,deque。

  • 5.stable_sort/stable_partial

    用于和目的于上面是一致的,只不过,这两个是稳定的排序,排序前后元素的前后顺序不会被打乱。

如何选择排序算法?

选择排序算法

消耗资源的顺序(从少到多)

  • 1.partition
  • 2.stable_partial
  • 3.nth_element
  • 4.partial_sort
  • 5.sort
  • 6.stable_sort

转载于:https://www.cnblogs.com/liangjf/p/10634083.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值