set 自定义谓词

对于一个模板类,比如A,在我们要定义一个具体的对象时,A<type, type...> obj, 注意type永远只能是类型,而不能是某个对象


#include <iostream>
#include <set>
using namespace std;
/**
*自定义比较函数
*/
bool fcmp(int l,int r)
{
    return l>r;
}
/**
*自定义一个函数对象类,如果flag为真,那么按升序,否则按降序,默认是降序
*/
template <class T>
class clscmp{
private:
    bool flag;
public:
    clscmp(bool f=false):flag(f){}
    bool operator()(const T &a,const T &b)
    {
        return flag?(a>b):(a<b);
    }
};
//自定义一个set类型,排序规则按照clscmp的规则排序
typedef set<int,clscmp<int> > Initset;//自定义set容器的类型,其中第三个参数类型是clscmp<int>类型
typedef bool (*fcmp_t)(int, int);
int main()
{
  int a[5]={1,2,3,4,5};

  Initset set1(a, a+5, false);//第三个参数是clscmp<int>类型,false是函数对象类初始化一个对象的参数
  Initset::iterator pos;
  for (pos = set1.begin(); pos != set1.end(); pos++) {
	  cout << *pos << endl;
  }

  //bool (*fp)(int ,int )=fcmp; //定义函数指针,将其作为set的排序规则
  //set<int,bool(*)(int,int)> set2(a, a+5, fp);
  fcmp_t fp = &fcmp;
  set<int, fcmp_t> set2(a, a+5, fp);//第三个参数是一个函数指针,fcmp_t是第三个参数类型
  for (pos = set2.begin(); pos != set2.end(); pos++) {
	  cout << *pos << endl;
  }
  return 0;
}

转载于:https://my.oschina.net/u/178323/blog/33169

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值