本文演示如何在 Visual C++中使用 set::find
标准模板库 (STL) 函数。
原始产品版本: Visual C++
原始 KB 数: 158576
必需的标头
<set>
原型
template<class _K, class _Pr, class _A>
class set
{
public:
// Function 1:
const_iterator find(const _K& _Kv) const;
}
注意
原型中的类/参数名称可能与头文件中的版本不匹配。 一些已修改以提高可读性。
set::find 函数的说明
该 find
函数用于查找受控序列中的元素。 它将迭代器返回到受控序列中的第一个元素,该元素的排序键与其参数匹配。 如果不存在此类元素,则返回的迭代器等于 end()
。
代码示例
注意
在 Visual C++ .NET 和 Visual C++ 中, /EHsc 默认设置,等效于 /GX。
//////////////////////////////////////////////////////////////////////
// Compile options needed: -GX
// SetFind.cpp:
// Illustrates how to use the find function to get an iterator
// that points to the first element in the controlled sequence
// that has a particular sort key.
// Functions:
// find Returns an iterator that points to the first element
// in the controlled sequence that has the same sort key
// as the value passed to the find function. If no such
// element exists, the iterator equals end().
// Copyright (c) 1996 Microsoft Corporation. All rights reserved.
//////////////////////////////////////////////////////////////////////
#pragma warning(disable:4786)
#include <set>
#include <iostream>
#if _MSC_VER > 1020 // if VC++ version is > 4.2
using namespace std; // std c++ libs implemented in std
#endif
typedef set<int,less<int>,allocator<int> > SET_INT;
void truefalse(int x)
{
cout << (x?"True":"False") << endl;
}
void main()
{
SET_INT s1;
cout << "s1.insert(5)" << endl;
s1.insert(5);
cout << "s1.insert(8)" << endl;
s1.insert(8);
cout << "s1.insert(12)" << endl;
s1.insert(12);
SET_INT::iterator it;
cout << "it=find(8)" << endl;
it=s1.find(8);
cout << "it!=s1.end() returned ";
truefalse(it!=s1.end()); // True
cout << "it=find(6)" << endl;
it=s1.find(6);
cout << "it!=s1.end() returned ";
truefalse(it!=s1.end()); // False
}
程序输出
s1.insert(5)
s1.insert(8)
s1.insert(12)
it=find(8)
it!=s1.end() returned True
it=find(6)
it!=s1.end() returned False