not1,not2,bind1st和bind2nd详解
来源:互联网 发布:mac注销用户快捷键 编辑:程序博客网 时间:2024/05/17 08:42
not1,not2,bind1st和bind2nd详解
转载来源:http://www.cnblogs.com/blueoverflow/p/4737122.html
1.引言 bind1st和bind2nd函数用于将一个二元函数对象(binary functor,bf)转换成一元函数对象(unary functor,uf)。为了达到这个目的,它们需要两个参数:要转换的bf和一个值(v)。
可能这么解释以后大家还不是很清楚,那么就说点白话吧。我们在做比较的时候所写的表达式像 x > k ,x < k,这里的k是一个参数表示你程序里面的表达式要和k值去比较。上面这两个表达式对应的应该是bind2nd ,简单的理解就是把k作为比较表达式的第二个参数。如果使用bind1st则对应的表达式是 k > x,k < x,也就是把k作为比较表达式的第一个参数。大家可能会注意到这里面没有=的比较,先别着急,后面将会说道如何实现=的比较。先举两个例子看看bind1st和bind2nd的用法。
f = std::bind1st( functor, v); 'f( x)'等价于'functor( v, x)'
f = std::bind2nd( functor, v); 'f( x)'等价于'functor( x, v)'
2.bind1st和bind2nd例子
int a[] = {1, 2, 100, 200};std::vector< int> arr(a, a + 4);// 移除所有小于100的元素arr.erase( std::remove_if( arr.begin(), arr.end(),std::bind2nd( std::less< int>(), 100)), arr.end());// 这里的比较表达式相当于arr.value < 100,如果用bind1st则表达的意思就恰恰相反// 移除所有大于100的元素arr.erase( std::remove_if( arr.begin(), arr.end(),std::bind1st( std::less< int>(), 100)), arr.end());// 这里的表达式相当于100 < arr.value,然为了实现删除大于100的元素你同样可以使用bind2nd// 移除所有大于100的元素arr.erase( std::remove_if( arr.begin(), arr.end(),std::bind2nd( std::greater< int>(), 100)), arr.end());// 前面说道=的比较,比如说x <= k怎么实现呢,std又提供了一个好东西not1,我们可以说 !(x > k) 和 x <= k是等价的,那么我们看看下面的表达式:// 移除所有小于等于100的元素arr.erase( std::remove_if( arr.begin(), arr.end(),std::not1(std::bind2nd( std::greater< int>(), 100))), arr.end());
3.not1和not2例子
not1是构造一个与谓词结果相反的一元函数对象,not2是构造一个与谓词结果相反的二元函数对象。
3.1 not1例子
#include <iostream> // std::cout#include <functional> // std::not1#include <algorithm> // std::count_ifstruct IsOdd{ bool operator() (const int& x) const { return x%2==1; } typedef int argument_type;};int main (){ int values[] = {1,2,3,4,5}; int cx = std::count_if (values, values+5, std::not1(IsOdd())); std::cout << "There are " << cx << " elements with even values.\n"; return 0;}3.2 not2例子
#include <iostream> // std::cout#include <functional> // std::not2, std::equal_to#include <algorithm> // std::mismatch#include <utility> // std::pairusing namespace std;int main(){ int foo[] = {10,20,30,40,50}; int bar[] = {0,15,30,45,60}; pair<int*,int*> firstmatch,firstmismatch; firstmismatch = mismatch (foo, foo+5, bar, equal_to<int>()); firstmatch = mismatch (foo, foo+5, bar, not2(equal_to<int>())); cout << "First mismatch in bar is " << *firstmismatch.second << '\n'; cout << "First match in bar is " << *firstmatch.second << '\n'; return 0;}
阅读全文
0 0
- not1,not2,bind1st和bind2nd详解
- bind1st,bind2nd,not1,not2
- 【STL】函数 for_each; bind1st和bind2nd,not1; mem_fun和mem_fun_ref;
- stl中 bind1st和 bind2nd 以及not1等适配器的使用
- not1 & not2
- STL bind1st bind2nd详解
- STL bind1st bind2nd详解
- bind1st bind2nd详解
- bind2nd 和 bind1st【转】
- bind1st和bind2nd函数
- bind1st 和 bind2nd 解析
- bind1st和bind2nd
- 理解bind1st和bind2nd函数
- bind1st 和 bind2nd的区别
- stl 中bind1st和bind2nd
- bind1st & bind2nd
- mem_fun_ref,mem_fun,not1,not2,ptr_fun
- mem_fun_ref,mem_fun,not1,not2,ptr_fun
- tomcat系列之 什么是tomcat
- Java集合深入学习:ArrayList的实现原理
- Python简明教程
- HDOJ2022
- 选项卡的完整代码~~还有一些自己copy
- not1,not2,bind1st和bind2nd详解
- HDOJ2024
- Studio用布局编辑器设计UI界面
- 两个整数的交换方法
- <ACM>求多边形重心和面积问题
- bzoj4976 宝石镶嵌
- HDOJ2025
- CSS常用属性计算原理
- 忘记在哪儿找的了,Excel中的图片抽取