std::find,std::find_if对类进行查找

本文介绍了如何使用STL的find及find_if函数对数组、容器进行查找。针对不同类型的元素提供了具体的实现方法,包括基本类型和自定义类型的查找,并展示了如何通过重载运算符或自定义谓词函数来实现。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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

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

 

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类定义如下:

 

class CPerson

{

public:

CPerson(void); ~CPerson(void);

 

public:

int age; // 年龄

};

 

那么如何用find()函数进行查找呢?这时,我们需要提供一个判断两个CPerson对象“相等”的定义,find()函数才能从一个list中找到与指定的CPerson“相等”的元素。

这个“相等”的定义,是通过重载“==”操作符实现的,我们在CPerson类中添加一个方法,定义为:

 

bool operator==(const CPerson &rhs) const;

 

实现为:

 

 

bool CPerson::operator==(const CPerson &rhs) const

{

return (id == rhs.age);

}

然后我们就可以这样查找(假设list中已经有了若干CPerson对象)了:
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的元素,找到的话就得到对象的指针。

这时候,你不再能像上面的例子那样做,我们需要用到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类外部定义这样一个结构体:
typedef struct finder_t
{
finder_t(int n) : age(n) { } bool operator()(CPerson *p) { return (age == p->age); } int age;
}finder_t;
然后就可以利用find_if函数来查找了:
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

}

 

评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值