当键是一对时,在映射中使用.find()函数

时间:2013-01-10 18:06:20

标签: c++ dictionary std-pair

我使用一对字符串作为地图中的键,并使用int作为值。我想在地图中搜索,如果确切的对已存在,则递增该值,否则将该对插入到地图中(值为1)。然而,它编译它实际上并没有找到已经存在的对,它只是插入。 (输出仅用于测试目的)。我认为问题在于使用.find()配对,但不知道如何解决这个问题......

2 个答案:

答案 0 :(得分:1)

您显示的代码似乎是正确的。你能用一个完整的例子来证明,包括main吗?

此外,我认为你可以逃脱operator[]

++pairs[std::make_pair(*slow, *fast)];

然而,真正的问题可能是你期望pairs成为“out”参数,而你是按值传递它。您的功能实际上只是修改容器的副本。你想通过引用来取而代之。 map<pair<string, string>, int> findPairs(map<pair<std::string,std::string>, int>& pairs, multiset<string> artists){(请注意&参数前的pairs

答案 1 :(得分:0)

邮政编码

没有错

但是,你所做的太多了。例如,此代码为

yo=pairs.find(p);
if (yo==pairs.end()) 
{
  pairs.insert(make_pair(p,1));
  cout<<"inserted"<<endl;
}
else 
{
   yo->second+=1;
   cout<<"entered"<<endl;
}

完全等同于:

pairs.insert(make_pair(p,1)).first->second += 1;

与此完全相同:

++pairs[p];

这意味着整个代码可以只用++pairs[p]替换,或者只是这样:

++pairs[make_pair(*slow, *fast)];

因为p毕竟是make_pair(*slow, *fast)