C++ functional库中的仿函数
一、仿函数简介
仿函数(functor)又称之为函数对象(function object),实际上就是 重载了()操作符 的 struct或class。
由于重载了()操作符,所以使用他的时候就像在调用函数一样,于是就被称为“仿”函数啦。
二、仿函数简要写法示例
一个很正常的需求,定义一个仿函数作为一个数组的排序规则:
将数组从大到小排序
class Cmp {
public:
bool operator()(const int &a, const int &b) {
return a > b;
}
};
使用:
vector<int> a(10);
iota(begin(a), end(a), 1);
sort(begin(a), end(a), Cmp()); // 使用()
for (auto x : a) {
cout << x << " ";
}
输出:
10 9 8 7 6 5 4 3 2 1
三、使用C++自带的仿函数
在C++ 的functional头文件中,已经为我们提供好了一些仿函数,可以直接使用。
(1)算术仿函数
1.plus 计算两数之和
例:将两个等长数组相加
vector<int> a(10), b(a);
iota(begin(a), end(a), 1);
iota(begin(b), end(b), 1);
transform(begin(a), end(a), begin(b), begin(a), plus<int>());
for (auto x : a) {
cout << x << " ";
}
输出:
2 4 6 8 10 12 14 16 18 20
2.minus 两数相减
将上面那个例子改一改:
transform(begin(a), end(a), begin(b), begin(a), minus<int>());
输出:
0 0 0 0 0 0 0 0 0 0
3.multiplies 两数相乘
再将上面那个例子改一改:
transform(begin(a), end(a), begin(b), begin(a), multiplies<int>());
输出:
1 4 9 16 25 36 49 64 81 100
4.divides 两数相除
还将上面那个例子改一改:
transform(begin(a), end(a), begin(b), begin(a), divides<int>());
输出:
1 1 1 1 1 1 1 1 1 1
5.modules 取模运算
继续将上面那个例子改一改:
transform(begin(a), end(a), begin(b), begin(a), modulus<int>());
输出:
0 0 0 0 0 0 0 0 0 0
6.negate 相反数
这次不能那样改了,因为上述的五个仿函数是二元仿函数,是对两个操作数而言的。
negate是一元仿函数,只能对一个参数求相反数。
所以我们对a数组求相反数:
transform(begin(a), end(a), begin(a), negate<int>());
输出:
-1 -2 -3 -4 -5 -6 -7 -8 -9 -10
(2)关系仿函数
1.equal_to 是否相等
2.not_equal_to 是否不相等
3.greater 大于
4.less 小于
5.greater_equal 大于等于
6.less_equal 小于等于
到这时,我们就可以看出,可以使用 greater() 来代替我们开头实现的例子
将数组从大到小排序:
vector<int> a(10);
iota(begin(a), end(a), 1);
sort(begin(a), end(a), greater<int>()); // 使用()
for (auto x : a) {
cout << x << " ";
}
输出:
10 9 8 7 6 5 4 3 2 1
(3)逻辑仿函数
1.logical_and 二元,求&
2.logical_or 二元,求|
3.logical_not 一元,求!
使用方法同上.
话说,并没有发现求异或的仿函数..
C++ functional库中的仿函数的更多相关文章
- 8、泛型程序设计与c++标准模板库4.标准c++库中的算法
标准c++算法是通过迭代器和模板来实现的,其实算法本身就是一种函数模板. 算法从迭代器那里获得一个元素,而迭代器则知道一个元素在容器中的什么位置.迭代器查找元素的位置并将这些信息提供给算法以便算法能够 ...
- 【Linux开发】OpenCV在ARM-linux上的移植过程遇到的问题4---共享库中嵌套库带路径【已解决】
[Linux开发]OpenCV在ARM-linux上的移植过程遇到的问题4-共享库中嵌套库带路径[已解决] 标签:[Linux开发] 紧接着上一篇,我居然又尝试了一下编译opencv,主要是因为由于交 ...
- 在Azure上的VM镜像库中找到想要的镜像
Azure上的虚机镜像库中, 有很多的镜像,其中当然也包括了用户自定义上传的镜像. 在Powershell中如果想使用这些镜像的话, 则需要知道其名称 下面这条命令,可以获得所有的镜像信息 $imag ...
- Arduino下LCD1602综合探究(下)——如何减少1602的连线,LiquidCrystal库,LiquidCrystal库中bug的解决方法
一.前言: 上文中,笔者系统的阐述了1602的两种驱动方式,并简单的提到了Arduino的LiquidCrystal库.本文紧接上文,对以下两个问题进行更加深入的探讨:如何能够使1602对Arduin ...
- SharePoint 2013 文档库中PPT转换PDF
通过使用 PowerPoint Automation Services,可以从 PowerPoint 二进制文件格式 (.ppt) 和 PowerPoint Open XML 文件格式 (.pptx) ...
- sql 从一个库中取某个表的数据导入到另一个库中相同结构的表中
sql 2008 从一个库中把 某个表中的数据导入到另一个库中的具有相同结构的表中 use 库1 go insert into 库1.dbo.表1 select * from 库2.dbo.表1 ...
- soapUI使用-DataSource获取oracle库中的参数
soapUI使用-DataSource获取oracle库中的参数 下载mysql和oracle驱动包:http://pan.baidu.com/s/1i3sy1MH 放在Program Files\S ...
- XLL 框架库中的函数
这个框架库,可以让编写 XLL 更加容易.包含了管理 XLOPER/XLOPER12 内存的简单函数,创建临时 XLOPER/XLOEPR12 ,强制调用回调函数 (Excel4,Excel4v,Ex ...
- eclipse 本地项目提交到远程库以及从远程库中添加项目 ---git
本地项目提交到远程库 1.右击项目->team->share project 2.选择本地库 从远处库中的项目拉到本地 1.右击项目->import项目
随机推荐
- C#处理医学影像(三):基于漫水边界自动选取病灶范围的实现思路
开发背景: 医生在实际使用PACS软件观察病灶时,经常会测量不规则病灶的周长和面积,使用画笔工具勾勒比较耗时且准度欠佳, 或者在标记人工智能训练样本时少则几百张,多则几千张,为极大减少耗时和极大提高工 ...
- C++ 接口的实现方式
一.接口的定义 有时候,我们得提供一些接口给别人使用.接口的作用,就是提供一个与其他系统交互的方法.其他系统无需了解你内部细节,并且也无法了解内部细节,只能通过你提供 给外部的接口来与你进行通信.根据 ...
- 程序语言与编程实践4-> 蓝桥杯C/C++备赛记录2 | 第二周学习训练
0323,又是一周星期三,按道理该总结了.这周前几天写题比较多,后面事情多了起来,就没怎么写了.主要方向是洛谷的基本语法熟悉,PTA平台数据结构的一些题目. 0323附上: 题目比较多,所以文章可能有 ...
- 内网渗透----Linux下信息收集
基础信息 1.系统类型 cat /etc/issue查看系统名称 Lsb-release查看系统名称.版本号 2. 内核版本 uname –a 查看所有信息 ls /root |grep vmlinu ...
- 域渗透 | kerberos认证及过程中产生的攻击
文章首发于公众号<Z2O安全攻防> 直接公众号文章复制过来的,排版可能有点乱, 可以去公众号看. https://mp.weixin.qq.com/s/WMGkQoMnQdyG8UmS ...
- [bzoj2878][Noi2012]迷失游乐园(基环树dp)
[bzoj2878][Noi2012]迷失游乐园(基环树dp) bzoj luogu 题意:一颗数或是基环树,随机从某个点开始一直走,不走已经到过的点,求无路可走时的路径长期望. 对于一棵树: 用两个 ...
- spring-boot-EnvironmentPostProcessor
原理: 1-从启动类入口的run方法进入: public ConfigurableApplicationContext run(String... args) { -SpringApplication ...
- Linux下离线安装docker与fastDFS
一.Linux下离线安装Docker 基础环境 1.操作系统:CentOS 7 2.Docker版本:docker-19.03.9.tgz 官方下载地址(打不开可能需要科学-上网) 3.官方参考文档: ...
- CopyOnWriteArrayList 可以用于什么应用场景?
CopyOnWriteArrayList(免锁容器)的好处之一是当多个迭代器同时遍历和修改这 个列表时,不会抛出 ConcurrentModificationException.在 CopyOnWri ...
- 为什么 wait 和 notify 方法要在同步块中调用?
Java API 强制要求这样做,如果你不这么做,你的代码会抛出 IllegalMonitorStateException 异常.还有一个原因是为了避免 wait 和 notify 之间产生竞态条件.