관리 메뉴

Kim's Programming

Algorithm - find_if() 본문

STL - Algorithm/Algorithm - Non-Modifying

Algorithm - find_if()

Programmer. 2017. 7. 13. 17:21

원형)


1
2
template <class InputIterator, class UnaryPredicate>
   InputIterator find_if (InputIterator first, InputIterator last, UnaryPredicate pred);
cs



의미)


[Iterator first, Iterator last) 사이에 있는 원소 중에서  pred에 대하여 true를 리턴하는 첫 원소를 가리키는 Iterator를 리턴합니다.



소스)


1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
#include<iostream>
#include<algorithm>
#include<vector>
 
bool isOdd(int val)
{
    return val % == 1;
}
 
void main()
{
    std::vector<int> vector = { 0,2,4,6,8,10 };
    std::vector<int>::iterator iter;
    iter = std::find_if(vector.begin(), vector.end(), isOdd);
    if (iter != vector.end())
        std::cout << "odd value -> " << *iter << std::endl;
    else
        std::cout << "No data" << std::endl;
}
cs



내용)


[Iterator first, Iterator last) 사이에 있는 원소 중에서  pred에 대하여 true를 리턴하는 첫 원소를 가리키는 Iterator를 리턴합니다. 모든 원소에 대해서 pred의 리턴값이 false라면 Iterator last를 리턴합니다.



결과)





'STL - Algorithm > Algorithm - Non-Modifying' 카테고리의 다른 글

Algorithm - find_end()  (0) 2017.07.14
Algorithm - find_if_not()  (0) 2017.07.13
Algorithm - find()  (0) 2017.07.13
Algorithm - for_each()  (0) 2017.07.13
Algorithm - none_of()  (0) 2017.07.13