使用std::find可查找vector中元素,找到返回迭代器,否则返回end();自定义类型需重载==或用std::find_if配合谓词;判断存在性可用封装函数contains。

在C++中,查找vector中的指定元素有多种方法,最常用的是使用标准库算法std::find。它结合迭代器可以快速判断元素是否存在,并获取其位置。
使用 std::find 查找元素
std::find定义在
基本用法:
- 如果找到元素,返回指向该元素的迭代器。
- 如果未找到,返回指向vector末尾的迭代器(即vec.end())。
示例代码:
立即学习“C++免费学习笔记(深入)”;
#include iostream>#include
#include
int main() {
std::vector
int target = 30;
auto it = std::find(vec.begin(), vec.end(), target);
if (it != vec.end()) {
std::cout } else {
std::cout }
return 0;
}
查找自定义类型元素
若vector中存储的是类或结构体对象,需要重载==运算符,或使用std::find_if配合谓词函数进行匹配。
示例:使用 find_if 查找满足条件的对象
struct Person {std::string name;
int age;
};
std::vector
auto it = std::find_if(people.begin(), people.end(),
[](const Person& p) { return p.name == "Bob"; });
if (it != people.end()) {
std::cout name age }
简单判断元素是否存在
如果只需要判断元素是否存在,不关心位置,可以封装一个简单的函数:
bool contains(const std::vectorreturn std::find(vec.begin(), vec.end(), value) != vec.end();
}
调用时直接使用:if (contains(vec, 30)) { ... }
基本上就这些。对于基础类型,std::find最直接;对复杂类型,搭配find_if更灵活。注意包含必要的头文件,合理使用迭代器和lambda表达式。不复杂但容易忽略细节。











