通过hashmap c 迭代
Iterate through HashMap C++
如何通过hashmap(c (迭代以便我可以浏览所有元素?
我有这个命名地图:
HashMap<std::string, int> map;
map.insert (key1, value1);
map.insert (key2, value2);
map.insert (key3, value3);
...
...
...
map.insert (keyN, valueN);
hash_map
已弃用,但是相同的原则适用...您可以使用范围循环(在这种情况下,使用 unordered_map (
使用Auto会像以下方式一样:
#include <iostream>
#include <string>
#include <unordered_map>
int main()
{
std::unordered_map<std::string, int> myMap;
myMap.insert(std::pair<std::string, int>("a", 1));
myMap.insert(std::pair<std::string, int>("b", 2));
myMap.insert(std::pair<std::string, int>("c", 3));
myMap.insert(std::pair<std::string, int>("d", 4));
for (const auto& x : myMap)
{
std::cout << "fisrt: " << x.first << ", second: " << x.second << std::endl;
}
std::cin.get();
return 0;
}
如果它具有begin((和end((成员函数,则应该可以简单地将其放在范围循环中。
for (auto& entry : map)
//whatever you want here
相关文章:
- 使用std::multimap迭代器创建std::list
- 来自 std::list 的迭代器 .end() 按预期返回"0xcdcdcdcdcdcdcdcd"但 .begin()
- C++中带有List类的迭代器Segfault
- 迭代时从向量和内存中删除对象
- 如何在c++迭代器类型中包装std::chrono
- 带过滤器的现代迭代c++集合
- 在c++中检查长方体是否尽可能快地重叠(无迭代)
- C++矢量迭代
- 集合上的输出迭代器:assign和increment迭代器
- Boost Spirit,获取迭代器内部语义动作
- 擦除while循环中迭代的元素
- 实现一个在集合上迭代的模板函数
- 对于set上的循环-获取next元素迭代器
- 在向量内的向量上迭代
- 为什么output_editor Concept不需要output_e迭代器标记
- TSP递归解的迭代形式
- c++17文件系统::recursive_directory迭代器()在mac上没有给出这样的目录,但在windows上
- 使用迭代器时如何访问对象在向量中的位置?
- std::vector::迭代器是否可以合法地作为指针
- 通过hashmap c 迭代