内建函数对象:STL内建了一些函数对象,调用时需引入头文件<functional>
算数仿函数:negate,modulus,divide,multiplies,minus,plus
#include <iostream>
#include<functional>
using namespace std;
//内建仿函数
//算术仿函数
//除取反操作外都是二元仿函数
void test1()
{
//negate 取反 一元仿函数
negate<int>n;
cout << n(50) << endl;
//plus 加法
plus<int>p;
cout << p(10, 20) << endl;
}
关系仿函数 equal_to,not_equal_to,greater,greater_equal,less,less_equal
#include <iostream>
#include<vector>
#include<functional>
#include<algorithm>
using namespace std;
//内建仿函数
//关系仿函数
//大于 greater
void test1()
{
vector<int>v;
v.push_back(10);
v.push_back(30);
v.push_back(40);
v.push_back(20);
for (vector<int>::iterator it = v.begin(); it != v.end(); it++)
{
cout << *it;
}
cout << endl;
//降序
//利用内建函数实现降序排序
sort(v.begin(), v.end(), greater<int>());
}
逻辑仿函数 logical_and,logical_or,logical_not
#include <iostream>
#include<vector>
#include<functional>
#include<algorithm>
using namespace std;
//内建仿函数
//逻辑仿函数
//逻辑非 logical_not
void test1()
{
vector<bool>v;
v.push_back(true);
v.push_back(true);
v.push_back(false);
v.push_back(false);
for (vector<bool>::iterator it = v.begin(); it != v.end(); it++)
{
cout << *it << endl;
}
//利用逻辑非将容器v搬运到v2中,并执行反操作
vector<bool>v2;
//搬运需要先指定容器大小
v2.resize(v.size());
transform(v.begin(), v.end(), v2.begin(), logical_not<bool>());
}