C++算法库(4)排序操作


/*is_sorted    检测指定范围是否已排序*/

/*is_sorted    检测指定范围是否已排序*/
#include <iostream>
#include <algorithm>
#include <array>
using namespace std;

int main(int argc, const char * argv[])
{

    array<int, 4> foo = {2,4,1,3};
   
    do {
        prev_permutation(foo.begin(), foo.end());
        cout<<"foo: ";
        for (int& x:foo)
            cout<<" "<<x;
        cout<<endl;
        
        } while (!is_sorted(foo.begin(), foo.end()));
    return 0;
}

/*is_sorted_until    返回最大已排序子范围*/

#include <iostream>
#include <algorithm>
#include <array>
using namespace std;

int main(int argc, const char * argv[])
{

    array<int, 4> foo = {2,4,1,3};
    array<int, 4>::iterator it;
    
    do {
        prev_permutation(foo.begin(), foo.end());
        cout<<"foo:";
        for (int& x:foo)
            cout<<" "<<x;
        it = is_sorted_until(foo.begin(), foo.end());
        cout <<" ( "<< (it - foo.begin())<<" elements sorted)"<<endl;
            
    } while (it != foo.end());

    
    return 0;
}


/*nth_element    部份排序指定范围中的元素,使得范围按给定位置处的元素划分*/

/*nth_element    部份排序指定范围中的元素,使得范围按给定位置处的元素划分*/
#include <iostream>
#include <algorithm>
#include <vector>
using namespace std;

bool myfunction(int i ,int j){return (i < j);}


int main(int argc, const char * argv[])
{

    int myints[] = {9,8,7,6,5,4,3,2,1};
    vector<int> myvector(myints ,myints + 9);
    vector<int>::iterator it;
    
    //using default comparison (operator <):
    partial_sort(myvector.begin(), myvector.begin() + 2, myvector.end());
    
    //using function as comp
    partial_sort(myvector.begin(), myvector.begin() + 4, myvector.end(), myfunction);
    
    //print out content:
    cout<<"myvector contains:";
    for (it = myvector.begin(); it != myvector.end(); ++it)
        cout<<" "<<*it;
    cout<<endl;
    
    return 0;
}








  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

杜甲同学

感谢打赏,我会继续努力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值