谓词实现sort的降排列数据

谓词听起来象英语中的谓语动词,但并不是这样,它是一个函数,返回bool结果的函数,这些函数在标准库中有很多用法。

都知道使用sort都是以升序排列值的,但如果要降序排列数据呢?函数sort充许提供一个谓词函数(called pred)用于比较项。

排序谓词函数必须满足以下条件:

1.pred(a,a)必须为false

2.如果pred(a,b)为true,且pred(,b,c)为true,则pred(a,c)必须为true

3.形参类型必须和待排序的元素类型相匹配

4.返回值类型必须为bool,或者C++可以自动转换为bool的类型

如果不提供谓词,sort使用操作符<作为默认比较

 

EXAMPLE

 

#include <algorithm>
#include <iostream>
#include <istream>
#include <ostream>
#include <iterator>
#include <vector>

//实现降序排列的谓词
bool descending(int a,int b)
{
 return a > b;
}

int main()
{
 std::vector<int> data;

 data.insert(data.begin(),std::istream_iterator<int>(std::cin),std::istream_iterator<int>());
 std::sort(data.begin(),data.end(),descending);//使用提供的谓词

 std::copy(data.begin(),data.end(),std::ostream_iterator<int>(std::cout,"\n"));
}

 

POSSIBLE OUTPUT

 

当然也可以通过sort后再使用reverse来实现降序输出...

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值