![](/img/trans.png)
[英]How to sort vector< pair< int , pair<int , pair<string , pair<int , int > > > > >?
[英]map<string, vector <pair<int, int> > > pushing back into pair?
我有这个map<string, vector <pair<int, int> > >
变量,我正在推回一个值,但是code :: blocks告诉我该对没有一个名为push_back的成员函数。 我该怎么做才能让它回推对而不是pair<>.push_back()
?
这基本上就是我在做什么:
map<string, vector <pair<int, int> > > T;
for(int x = 0; x < data.size(); x++)
T[data[x].str].push_back(data[x].PAIR)
而错误是:
error: no matching function for call to 'std::vector<std::pair<int, int>,
std::allocator<std::pair<int, int> > >::push_back(std::map<int, int,
std::less<int>, std::allocator<std::pair<const int, int> > >&)'
不确定你的问题。
以下代码对我来说很好:
map<string, vector <pair<int, int> > > T;
pair<int, int> p;
p.first = 1;
p.second = 10;
T["Hello"].push_back(p);
cout << T["Hello"][0].first << endl;
该消息表明您正在尝试推回std::map
,而不是一对。 你的data
结构是什么样的?
向量确实有push_back()方法。 最有可能的数据[x] .PAIR不是类型对。 什么类型的数据[x] .PAIR? 如果你将数据[x] .PAIR转换为配对它应该有效。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.