STL 算法Find_if_not+匿名函数

本文内容来自C++Plus,本文只是本人的总结和翻译而已。本人只是C++的搬运工。

原文传送门:http://www.cplusplus.com/reference/algorithm/find_if_not/

Find_if_not 算法(在指定范围内查找一个元素):

返回一个[first,last)区间范围内第一个符合查找条件的元素,查找函数的perd返回false的时候满足条件。如果在范围内没有找到符合的元素,就返回last。

template<class InputIterator, class UnaryPredicate>
  InputIterator find_if_not (InputIterator first, InputIterator last, UnaryPredicate pred)
{
  while (first!=last) {
    if (!pred(*first)) return first;
    ++first;
  }
  return last;
}
这个算法和First_if很相似,只是在判断返回条件的函数上有些许不同,First_if是Bool函数返回真的时候就return first,First_if_not刚好是相反的。

接下来是源码中的些许亮点

// find_if_not example
#include <iostream>     // std::cout
#include <algorithm>    // std::find_if_not
#include <array>        // std::array

int main () {
  std::array<int,5> foo = {1,2,3,4,5};

  std::array<int,5>::iterator it =
    std::find_if_not (foo.begin(), foo.end(), [](int i){return i%2;} );//匿名函数C++11标准
  std::cout << "The first even value is " << *it << '\n';

  return 0;
}


这里并没有一个bool函数,但是多了一个匿名函数,这样的写法在和算法配合使用的时候会让代码看上去更加的简洁。[]代表这是一个匿名函数,(int i)代表了这个函数的参数的类型。{return i%2} 里面就是这个函数的执行。



  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值