zoukankan      html  css  js  c++  java
  • std::find,std::find_if对类进行查找

    STL的find,find_if函数提供了一种对数组、STL容器进行查找的方法。使用该函数,需 #include <algorithm>

    我们查找一个list中的数据,通常用find(),例如:

    文章来源:http://www.codelast.com/

     

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    using namespace std;
     
    int main()
     
    {
     
    list<int> lst;
     
    lst.push_back(10);
     
    lst.push_back(20);
     
    lst.push_back(30);
     
    list<int>::iterator it = find(lst.begin(), lst.end(), 10); // 查找list中是否有元素“10”
     
    if (it != lst.end()) // 找到了
    {
    // do something
    }
    else // 没找到
    {
    // do something
    }
    return 0;
    }

    那么,如果容器里的元素是一个类呢?例如,有list<CPerson> ,其中CPerson类定义如下:

    1
    2
    3
    4
    5
    6
    7
    class CPerson
    {
    public:
    CPerson(void); ~CPerson(void);
    public:
    int age; // 年龄
    };
    那么如何用find()函数进行查找呢?这时,我们需要提供一个判断两个CPerson对象“相等”的定义,find()函数才能从一个list中找到与指定的CPerson“相等”的元素。
    文章来源:http://www.codelast.com/
    这个“相等”的定义,是通过重载“==”操作符实现的,我们在CPerson类中添加一个方法,定义为:
    1
    bool operator==(const CPerson &rhs) const;
    实现为:
    1
    2
    3
    4
    bool CPerson::operator==(const CPerson &rhs) const
    {
    return (id == rhs.age);
    }
     
    然后我们就可以这样查找(假设list中已经有了若干CPerson对象)了:
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    list<CPerson> lst;
    //////////////////////////////////
    // 向lst中添加元素,此处省略
    //////////////////////////////////
    CPerson cp_to_find; // 要查找的对象
    cp_to_find.age = 50;
    list<CPerson>::iterator it = find(list.begin(), list.end(), cp_to_find); // 查找
    if (it != lst.end()) // 找到了
    {
    // do something
    }
    else // 没找到
    {
    // do something
    }
    这样就实现了需求。
    有人说,如果我有自己定义的“相等”呢?例如,有一个list<CPerson*>,这个list中的每一个元素都是一个对象的指针,我们要在这个list中查找具有指定age的元素,找到的话就得到对象的指针。
    文章来源:http://www.codelast.com/
    这时候,你不再能像上面的例子那样做,我们需要用到find_if函数,并自己指定predicate function(即find_if函数的第三个参数,请查阅STL手册)。先看看find_if函数的定义:
    template<class InputIterator, class Predicate>
    InputIterator find_if(InputIterator _First, InputIterator _Last, Predicate _Pred);
    Parameters
    _First
    An input iterator addressing the position of the first element in the range
    to be searched.
    _Last
    An input iterator addressing the position one past the final element in the
    range to be searched.
    _Pred
    User-defined predicate function object that defines the condition to be
    satisfied by the element being searched for. A predicate takes single argument
    and returns true or false.
    我们在CPerson类外部定义这样一个结构体:
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    typedef struct finder_t
    {
    finder_t(int n)
    : age(n)
    {
    }
    bool operator()(CPerson *p)
    {
    return (age == p->age);
    }
    int age;
    }finder_t;
    然后就可以利用find_if函数来查找了:
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    list<CPerson*> lst;
    //////////////////////////////////
    // 向lst中添加元素,此处省略
    //////////////////////////////////
    list<CPerson*>::iterator it = find_if(lst.begin(), lst.end(), finder_t(50)); // 查找年龄为50的人
    if (it != lst.end()) // 找到了
    {
    cout << “Found person with age : ” << (*it)->age;
    }
    else // 没找到
    {
    // do something
    }
    if (it != lst.end()) // 找到了
    {
    // do something
    }
    else // 没找到
    {
    // do something
    }
     
    return 0;
     
    }
  • 相关阅读:
    POJ1475 Pushing Boxes 华丽丽的双重BFS
    POJ3322 Bloxorz I 无脑广搜(我死了。。。)
    CH2401 送礼物 双向搜索
    POJ2248 Addition Chains 迭代加深
    POJ3074 Sudoku 剪枝深(神?)搜
    Luogu P1120 小木棍 [数据加强版] 来来来我们一起来剪枝,剪枝,剪枝、、、
    Luogu P4095 [HEOI2013]Eden 的新背包问题 思维/动规
    Luogu P5201 [USACO19JAN]Shortcut 最短路树???
    Luogu P5122 [USACO18DEC]Fine Dining 最短路
    Luogu P1608 路径统计 最短路计数
  • 原文地址:https://www.cnblogs.com/hzcya1995/p/13318780.html
Copyright © 2011-2022 走看看