我有以下代码迭代 unordered_map 中的所有键,同时迭代我将映射传递给其他函数。由于某种原因,迭代器无法迭代所有键。我无法弄清楚为什么以及如何解决这个问题。如果我将地图作为值而不是引用传递,那么它会按预期工作,但我想通过引用传递来保存副本。
代码:
void DFS(char curr, unordered_map<char, unordered_set<char>>& G) {
cout << "Traversing: " << curr << endl;
for(const char& ch: G[curr]) {
DFS(ch, G);
}
}
int main() {
unordered_map<char, unordered_set<char>> G;
G['c'].emplace('b');
G['b'].emplace('a');
for(auto it : G) {
cout << "Starting with: " << it.first << endl;
DFS(it.first, G);
}
}
Run Code Online (Sandbox Code Playgroud)
我得到的输出是:
Starting with: b
Traversing: b
Traversing: a
Run Code Online (Sandbox Code Playgroud)
请注意,它不是遍历 key c。
更新: 更改 DFS 函数以使地图 const 如下所示也无济于事:
void DFS(const char curr, const unordered_map<char, unordered_set<char>>& G) {
cout << "Traversing: " << curr << endl;
for(auto ch: G.at(curr)) {
DFS(ch, G);
}
}
Run Code Online (Sandbox Code Playgroud)
它也抛出异常:
terminate called after throwing an instance of 'std::out_of_range'
what(): _Map_base::at
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
159 次 |
| 最近记录: |