给出以下在地图上进行反向查找的代码:
map<char, int> m = {{'a', 1}, {'b', 2}, {'c', 3}, {'d', 4}, {'e', 5}};
int findVal = 3;
Pair v = *find_if(m.begin(), m.end(), [findVal](const Pair & p) {
return p.second == findVal;
});
cout << v.second << "->" << v.first << "\n";
是否可以传递一个文字值(在本例中为 3),而不必将其存储在变量(即 findVal)中,以便可以通过捕获列表访问它?
显然,这种情况下的限制之一是 lambda 充当一元谓词的角色,因此我无法在括号之间传递它。
Thanks
你可以这样写:
Pair v = *find_if(m.begin(), m.end(), [](const Pair & p) {
return p.second == 3;
});
您不需要一开始就捕获它。
顺便说一句,你不应该假设std::find_if
就会找到该元素。更好的方法是使用迭代器:
auto it = find_if(m.begin(), m.end(), [](const Pair & p) {
return p.second == 3;
});
if (it == m.end() ) { /*value not found*/ }
else {
Pair v = *it;
//your code
}
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)