小编给大家分享一下C++ map如何实现根据value找key,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!
测试所需头文件
#include <algorithm>
#include <vector>
#include <map>
#include <string>
初始
std::map<int, std::string> t;
t.insert(std::make_pair(1, "a"));
t.insert(std::make_pair(2, "b"));
t.insert(std::make_pair(3, "c"));
t.insert(std::make_pair(4, "d"));
根据key 找 value
std::string s = "";
auto it = t.find(2);
if (it != t.end())
{
s = (*it).second;
}
根据value 找key lambda方式
std::string s = "c";
auto find_item = std::find_if(t.begin(), t.end(),
[s](const std::map<int, std::string>::value_type item)
{
return item.second == s;
});
int n = 0;
if (find_item!= t.end())
{
n = (*find_item).first;
}
根据value 找key 函数对象方式
class finder
{
public:
finder(const std::string &cmp_string) :s_(cmp_string){}
bool operator ()(const std::map<int, std::string>::value_type &item)
{
return item.second == s_;
}
private:
const std::string &s_;
};
//调用
int n = 0;
auto it = std::find_if(t.begin(), t.end(), finder("d"));
if (it != t.end())
{
n = (*it).first;
}
看完了这篇文章,相信你对“C++ map如何实现根据value找key”有了一定的了解,如果想了解更多相关知识,欢迎关注亿速云行业资讯频道,感谢各位的阅读!
亿速云「云服务器」,即开即用、新一代英特尔至强铂金CPU、三副本存储NVMe SSD云盘,价格低至29元/月。点击查看>>
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。