技术文摘
C++中用于哈希表的STL函数有哪些
2025-01-09 03:42:52 小编
C++中用于哈希表的STL函数有哪些
在C++的标准模板库(STL)中,哈希表相关的功能主要由unordered_map和unordered_set容器提供。下面来介绍一些常用的与哈希表相关的STL函数。
1. 构造函数
unordered_map和unordered_set的构造函数可以用于创建空的哈希表或者通过给定的范围进行初始化。例如:
#include <unordered_map>
#include <unordered_set>
std::unordered_map<int, std::string> myMap;
std::unordered_set<int> mySet = {1, 2, 3};
2. 插入元素
insert函数用于向哈希表中插入元素。对于unordered_map,插入的是键值对;对于unordered_set,插入的是单个元素。示例如下:
myMap.insert(std::make_pair(1, "one"));
mySet.insert(4);
3. 查找元素
find函数用于在哈希表中查找指定元素。如果找到,返回指向该元素的迭代器;否则,返回end迭代器。例如:
auto it = myMap.find(1);
if (it!= myMap.end()) {
std::cout << it->second << std::endl;
}
4. 删除元素
erase函数用于从哈希表中删除指定元素。可以通过键或者迭代器来指定要删除的元素。例如:
myMap.erase(1);
5. 遍历哈希表
可以使用迭代器来遍历哈希表中的元素。例如:
for (auto it = mySet.begin(); it!= mySet.end(); ++it) {
std::cout << *it << " ";
}
6. 大小和空判断
size函数返回哈希表中元素的个数。empty函数判断哈希表是否为空。示例如下:
std::cout << "Size of mySet: " << mySet.size() << std::endl;
if (myMap.empty()) {
std::cout << "myMap is empty." << std::endl;
}
C++ STL中的unordered_map和unordered_set提供了丰富的函数来操作哈希表,能够方便地实现各种数据存储和查找需求。熟练掌握这些函数对于提高C++编程效率非常有帮助。
- 必看的 7 本 JavaScript 学习之路书籍
- 群消息已读回执,究竟是推还是拉
- 浅析 Synchronized 的底层实现原理
- 9 款代码质量工具对比,哪款更优?
- 深入解析 JavaScript json 数组:一篇文章全知晓
- 链家程序员删 9TB 公司数据获刑 7 年
- Scrapy 网络爬虫框架初体验
- VUE 项目性能优化之懒加载加快页面响应速度
- Python 中的 __name__ 变量究竟为何物?
- 面试官提及分布式事务,我预感有望获 40k 高薪
- 十个程序员必备的摸鱼网站,快来畅玩!
- 鸿蒙 3.4 熟知的列表:HAP 中的单列表与组装列表
- 鸿蒙 HarmonyOS 开发板结合讯飞平台实现语音控制开关灯
- Spring Boot 可执行 jar 为何不能被其他项目依赖
- 鸿蒙 Harmony 应用开发的 view-binding 插件:告别 findComponentById