打印矢量元素

时间:2016-05-10 12:54:47

标签: c++ vector std-pair

在下面的代码中,我有一个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

 }
}

2 个答案:

答案 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;

Live Example

无论您对此结构的意图是什么,输入的a值都会对您的设计构成威胁:

  1. 没有检查看到你的跌倒在0到100之间
  2. 您甚至在知道n之前就分配了101个元素,这意味着这些元素的101 - n被浪费了。
  3. 在这种情况下,我认为使用map作为您的第一个维度将是一个更好的计划;所以你的结构看起来像是:

    map<int, vector<pair<int, string>>> aye;
    

    不需要对您的代码进行进一步更改,但只会n vector<pair<int, string>>分配n是否大于或小于101。