c++谓词和仿函数

谓词

  • 返回bool类型的仿函数

一元谓词

接收一个参数的仿函数

  • 定义
class GreaterFive
{
public:
    bool operator()(int val)
    {
        return val > 5;
    }
};
  • 使用,查找vector容器大于5的数,这个规则是谓词定义的
int main()
{
    vector<int> v;
    for (int i = 0; i < 10; i++)
    {
        v.push_back(i);
    }
    vector<int>::iterator it = find_if(v.begin(), v.end(), GreaterFive());

    if(it == v.end())
    {
        cout << "no find" << endl;
    }
    else
    {
        cout << *it << endl;
    }
    return 0;
}

二元谓词

接收两个参数的仿函数

  • 定义
class Decrease
{
public:
    bool operator()(int val1, int val2)
    {
        return val1 > val2;
    }
};
  • sort排序默认是升序,使用谓词重新定义规则为降序
int main()
{
    vector<int> v;

    v.push_back(10);
    v.push_back(30);
    v.push_back(50);
    v.push_back(60);
    v.push_back(20);

    sort(v.begin(), v.end(), Decrease());
    for(int i : v)
    {
        cout << i << endl;
    }

    return 0;
}

内建仿函数

所需头文件#include<functional>

算术仿函数

  • template<class T> T plus<T> 加法仿函数
  • template<class T> T minus<T> 减法仿函数
  • template<class T> T multiplies<T> 乘法仿函数
  • template<class T> T divides<T> 除法仿函数
  • template<class T> T modulus<T> 取模仿函数
  • template<class T> T negate<T> 取反仿函数

加法和取反的用法

分别演示两个参数和一个参数的用法

int main()
{
    plus<int> add;
    cout << add(10, 20) << endl;

    negate<int> n;
    cout << n(50) << endl;

    return 0;
}

输出结果为

30
-50

关系仿函数

可以当做谓词

  • template<class T> bool equal_to<T> 等于
  • template<class T> bool not_equal_to<T> 不等于
  • template<class T> bool greater<T> 大于
  • template<class T> bool greater_equal<T> 大于等于
  • template<class T> bool less<T> 小于
  • template<class T> bool less_equal<T> 小于等于

大于的用法

int main()
{
    vector<int> v;

    v.push_back(10);
    v.push_back(30);
    v.push_back(50);
    v.push_back(60);
    v.push_back(20);

    sort(v.begin(), v.end(), greater<int>());

    for(int i : v)
    {
        cout << i << endl;
    }

    return 0;
}

修改sort的排序规则为降序,使用内建仿函数,就不需要自己定义了,和二元谓词类似

逻辑仿函数

  • template<class T> bool logical_and<T> 逻辑与
  • template<class T> bool logical_or<T> 逻辑或
  • template<class T> bool logical_not<T> 逻辑非
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值