给出以下代码在地图上执行反向查找:
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正在填充一元谓词的角色,所以我不能在括号之间传递它。
由于
答案 0 :(得分:1)
你可以这样写:
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
}