我如何为像这样声明的map赋值?
map < map<int,int> , bool > Map;
我希望代码看起来像这样:
Map[u][v]=true;
其中u
或v
可以是最大10^5
。
我如何对此进行编码?
发布于 2018-09-20 06:11:17
你想要的是:
std::map<int, std::map<int, bool> > myMap;
然后,您可以通过以下方式设置/获取值:
bool myBool;
myMap[u][v] = myBool;
myBool = myMap[u][v];
发布于 2018-09-22 23:43:22
@WhozCraig在评论中指出,如果不需要map
的排序行为,那么unordered_map
是一个更快的选择。
std::unordered_map<int, std::unordered_map<int, bool> > myMap;
但是,使用帮助器类包装单个unordered_map
通常会将执行时间减半,因为只需执行一次散列即可查找两个整数。
class Map2ints
{
class Map2Helper {
int u;
std::unordered_map<int64_t, bool> &vmap;
public:
bool& operator[](int v) { return vmap[u | (static_cast<int64_t>(v) << 32)]; }
Map2Helper(int u, std::unordered_map<int64_t, bool> &vmap) :u(u), vmap(vmap) {}
};
std::unordered_map<int64_t, bool> vmap;
bool contains(int u, int v) { return vmap.find(u | (static_cast<int64_t>(v) << 32))!=vmap.end(); }
public:
Map2Helper operator[](int u) { return Map2Helper{ u, vmap }; }
};
那么用法应该是一样的。例如:
Map2ints myMap;
myMap[70000][151] = true;
bool a = myMap[70000][151]; // which sets a to true
https://stackoverflow.com/questions/52414826
复制相似问题