繁体   English   中英

C ++无序映射

[英]C++ Unordered Map

我有一个程序在其中使用迭代器来访问映射条目的值。

#include <iostream>
#include <cstdio>
#include <unordered_map>
#include <utility>
#include <algorithm>

using namespace std;

int main()
{
   int a[]={1,2,4,7,9,3,3,55,66,88,11};
   int k = 58;
   unordered_map<int,int> c;
   int i=0;
   for(auto x: a)
   {
       c.insert(make_pair(x,i));
       i++;
   }

   for(auto x: c)
   {
     if(c.count(k-x.first)==1) printf("%d %d\n",x.second,(c.find(k-x))->second);
   }

}

在该行中:

if(c.count(k-x.first)==1) printf("%d %d\n",x.second,(c.find(k-x))->second);

我遇到错误,尤其是在c.find()->second 我认为这是从迭代器访问元素的方式。 怎么了?

你不能说

c.find(k-x)

因为k是一个intx是一个std::pair<int, int> 您是这两个意思之一吗?

c.find(k - x.first)

要么

c.find(k - x.second)

附带说明一下,直接从find取消对返回的迭代器的引用通常是不安全的,因为如果find返回.end() (例如,它没有找到具有该键的元素),那么您就会遇到问题。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM