在下面的代码中,我有一个2D向量,在每个向量索引中,每对包含int和string。我正在尝试在获取向量中的值后访问每个元素。建议将非常感谢。
#include <bits/stdc++.h>
using namespace std;
vector<pair<int,string>> aye[101];
int main()
{ int n,m,i,a,b;
string x;
cin >> n >> m;
for (int i = 1; i <= n; ++i)
{
cin >> x;
cin >> a >> b;
aye[a].push_back(make_pair(-b,x));
cout<<aye[a].first<<aye[a].second;//this is not working
cout<<aye[a][0]<<aye[a][1]<<endl;//this is not working
}
}
答案 0 :(得分:1)
你似乎对你的二维阵列结构感到困惑(我不得不承认,我也有点困惑为什么你会使用这样的东西)。这样:
aye[a]
是数组的第(a + 1)个元素,它是一个向量,然后是
aye[a][i]
是该向量中的第(i + 1)个元素,它是一对和
aye[a][i].first
aye[a][i].second
分别是该对的第一个/第二个条目。
但是,我怀疑你真的需要一对双向量,特别是你似乎忽略了其余代码中的一个维度。
答案 1 :(得分:0)
您似乎正在尝试打印刚刚添加到vector
的元素来执行此操作,我建议使用vector::back
。你可以用这样的东西替换你的两条非工作线:
cout << aye[a].back().first << ' ' << aye[a].back().second;
无论您对此结构的意图是什么,输入的a
值都会对您的设计构成威胁:
n
之前就分配了101个元素,这意味着这些元素的101 - n
被浪费了。在这种情况下,我认为使用map
作为您的第一个维度将是一个更好的计划;所以你的结构看起来像是:
map<int, vector<pair<int, string>>> aye;
不需要对您的代码进行进一步更改,但只会n
vector<pair<int, string>>
分配n
是否大于或小于101。