基本操作员具有非指针类型
base operator has non pointer type
我想在此处迭代map<int,map<int,set<int>>> mep;
获取错误(" ->"的基本运算符,没有指针类型(以这种方式
for(auto p : mep){
vector<int> temp;
auto s = p->second->second;//getting here here
for(auto it : s){
temp.push_back(it);
}
result.push_back(temp);
}
您有三个嵌套容器。您应该期望有三个嵌套 for-loops :
std::vector<int> temp;
for (const auto& p1 : mep) {
for (const auto& p2 : p1.second) {
for (const int n : p2.second) {
temp.push_back(n);
}
}
}
注释:
- 在循环中使用
const auto&
(参考(。没有参考,您将创建副本。 - 尝试使用更好的命名约定来进行循环变量(即
p1
,p2
,n
(;根据您的上下文。 -
using namespace std;
被认为是不良习惯。推理在这里解释。
for(auto p : mep){
vector<int> temp;
auto s = p->second;
for(auto k : s){
auto ss = k->second;
for(auto it : ss)
temp.push_back(it);
}
result.push_back(temp);
}
p->第二个给您地图对象而不是迭代对象,因此没有 -> seconed,您有一个地图对象,需要在此映射对象上拥有新的迭代器
以下是相同的代码,该代码设置并打印为地图数据结构的设置值,
set<int> sv = { 1,2,3,4,5};
map<int, set<int>> ms = {{2,sv}, {1,sv}};
map<int, map<int,set<int>>> mep = {{1,ms}};
for (auto i:mep) { // Outer map iteration
for (auto j:i.second) { // Inner map iteration
for (auto s:j.second) { // Set iteration
cout<<"Set:"<< s;
}
}
}
根据您的需求,您可以修改此内容。
相关文章:
- C++中的双指针类型转换
- C++默认情况下,指针类型数组的元素是否保证初始化为 nullptr?
- 将类指针类型转换为键时出错
- 错误:表达式必须具有算术、无作用域枚举或带有运算符重载的指针类型
- C++在一个映射中存储不同的指针类型(并处理销毁)
- 指针类型类成员的动态强制转换的恒定性是什么?
- 我正在尝试将表的地址传递给要在另一个函数中使用的指针,但得到不兼容的指针类型
- 在将派生类指针类型转换为派生类指针后,从基类指针调用派生类函数
- 如何使用静态多态性在 int 和指针类型之间进行转换?
- STL 函数和函数类型与函数指针类型
- 如何调用指针类型的方法(禁用多态性)?
- 为什么新表达式可以正确生成指针类型,即使它应该返回 void*?
- 对于非常量指针类型的参数,未调用具有常量指针模板类型参数的功能
- 是否允许调用方对我的 Builder 类使用任何指针类型(包括智能指针)?
- OPENCL 警告:不兼容的指针类型将'float __global[16]'传递给类型为 '__global float4 的参数 *
- 专门用于"direct"函数类型(与函数指针类型相对)
- 指向成员的指针类型和模板
- 返回对常量结构(指针类型)成员的引用:明显的左值到右值转换
- 在C++17中,为什么类模板和函数模板的指针类型推导明显不一致
- 为什么允许将整型、枚举和指向成员的指针类型reinterpret_cast到自身?