C++ map find() 函数使用方法及示例
C++ STL map(容器)
C ++ map
find()
函数用于
查找
具有给定
键值k
的元素
。如果找到该元素,则返回指向该元素的迭代器。否则,它返回一个指向map末尾的迭代器,即map :: end()。
语法
iterator find (const key_type& k); // 在 C++ 11 之前
const_iterator find (const key_type& k) const; //从 C++ 11 开始
参数
k
:指定要在map容器中搜索的键。
返回值
如果找到该元素,则返回指向该元素的迭代器。否则,它返回一个指向map末尾的迭代器,即map :: end()。
实例1
让我们看一个简单的示例,查找具有给定键值的元素。
#include <iostream>
#include <map>
using namespace std;
int main(void) {
map<char, int> m = {
{'a', 100},
{'b', 200},
{'c', 300},
{'d', 400},
{'e', 500},
auto it = m.find('c');
cout << "迭代器指向 " << it->first <<
" = " << it->second << endl;
return 0;
}
输出:
迭代器指向 c = 300
在上面的示例中,find()函数返回给定键值'c'的值。
实例2
让我们看一个简单的示例来查找元素。
#include <iostream>
#include <map>
using namespace std;
int main(void) {
map<char, int> m = {
{'a', 100},
{'b', 200},
{'c', 300},
{'d', 400},
{'e', 500},
auto it = m.find('e');
if ( it == m.end() ) {
cout<<"找不到元素";
else {
// 找到元素
cout << "迭代器指向 " << it->first << " = " << it->second << endl;
return 0;
}
输出:
迭代器指向 e = 500
在上面的示例中,find()函数在map容器m中找到键值e,如果在map中未找到键值e,则它将返回未找到消息,否则将显示该map。
实例3
让我们看一个简单的实例。
#include <iostream>
#include <map>
using namespace std;
int main()
int n;
map<int,char> example = {{1,'a'},{2,'b'},{3,'c'},{4,'d'},{5,'e'} };
cout<<"输入您要搜索的元素: ";
cin>>n;
auto search = example.find(n);
if (search != example.end()) {
cout << n<<" 找到,值是 " << search->first << " = " << search->second << '\n';
} else {
cout << n<<" 未找到\n";
}
输出:
输入您要搜索的元素: 5
5 找到,值是 5 = e
在上面的示例中,使用find()函数根据用户给定的键值查找元素。
实例4
让我们看一个简单的实例。
#include <iostream>
#include <map>
using namespace std;
int main ()
map<char,int> mymap;
map<char,int>::iterator it;
mymap['a']=50;
mymap['b']=100;
mymap['c']=150;
mymap['d']=200;
it = mymap.find('b');
if (it != mymap.end())
mymap.erase (it);
cout << "mymap中的元素:" << '\n';
cout << "a => " << mymap.find('a')->second << '\n';
cout << "c => " << mymap.find('c')->second << '\n';
cout << "d => " << mymap.find('d')->second << '\n';
return 0;
}
输出:
mymap中的元素:
a => 50
c => 150
d => 200
C++ STL map(容器)