c++find(stlfind)查找算法
来源:千锋教育
发布人:zyh
2023-05-31
推荐
在C++的STL(标准模板库)中,std::find() 是一个查找算法,用于在容器或数组中查找特定值的元素。
函数原型:
ForwardIterator find(ForwardIterator first, ForwardIterator last, const T& value);
参数:
first 和 last:表示要查找的范围的迭代器,范围包括 first,但不包括 last。
value:要查找的值。
返回值:
如果找到匹配的值,则返回指向第一个匹配元素的迭代器。
如果未找到匹配的值,则返回 last。
示例:
#include <algorithm>
#include <vector>
#include <iostream>
int main() {
std::vector<int> nums = {1, 2, 3, 4, 5};
// 在容器中查找值为 3 的元素
auto it = std::find(nums.begin(), nums.end(), 3);
if (it != nums.end()) {
std::cout << "找到了元素:" << *it << std::endl;
} else {
std::cout << "未找到指定元素" << std::endl;
}
return 0;
}
输出:
找到了元素:3
std::find() 函数会从容器的起始位置开始逐个查找元素,直到找到匹配的元素或遍历完整个范围。如果找到匹配的元素,则返回指向第一个匹配元素的迭代器;如果未找到匹配的元素,则返回 last,即指向范围的结束位置的迭代器。
注意:std::find() 函数需要在代码中包含<algorithm> 头文件。