当前位置: 首页 > news >正文

【C++】无序容器unordered_set和unordered_map的使用

1. unordered_set系列的使用

1.1 unordered_set和unordered_multiset参考文档

https://legacy.cplusplus.com/reference/unordered_set/

1.2 unordered_set类的介绍

unordered_set底层是哈希表,而set底层是红黑树

1.3 unordered_set和set的使用差异

void test_set2() { const size_t N = 1000000; unordered_set<int> us; set<int> s; vector<int> v; v.reserve(N); srand(time(0)); for (size_t i = 0; i < N; ++i) { //v.push_back(rand()); // N比较大时,重复值比较多 v.push_back(rand() + i); // 重复值相对少 //sv.push_back(i); // 没有重复,有序 } size_t begin1 = clock(); for (auto e : v) { s.insert(e); } size_t end1 = clock(); cout << "set insert:" << end1 - begin1 << endl; size_t begin2 = clock(); us.reserve(N); for (auto e : v) { us.insert(e); } size_t end2 = clock(); cout << "unordered_set insert:" << end2 - begin2 << endl; int m1 = 0; size_t begin3 = clock(); for (auto e : v) { auto ret = s.find(e); if (ret != s.end()) { ++m1; } } size_t end3 = clock(); cout << "set find:" << end3 - begin3 << "->" << m1 << endl; int m2 = 0; size_t begin4 = clock(); for (auto e : v) { auto ret = us.find(e); if (ret != us.end()) { ++m2; } } size_t end4 = clock(); cout << "unorered_set find:" << end4 - begin4 << "->" << m2 << endl; cout << "插入数据个数:" << s.size() << endl; cout << "插入数据个数:" << us.size() << endl << endl; size_t begin5 = clock(); for (auto e : v) { s.erase(e); } size_t end5 = clock(); cout << "set erase:" << end5 - begin5 << endl; size_t begin6 = clock(); for (auto e : v) { us.erase(e); } size_t end6 = clock(); cout << "unordered_set erase:" << end6 - begin6 << endl << endl; }

1.4 unordered_map和map的使用差异

1.5 unordered_multimap/unordered_multiset

  • unordered_multimap/unordered_multiset跟multimap/multiset功能完全类似,⽀持Key冗余。
  • unordered_multimap/unordered_multiset跟multimap/multiset的差异也是三个⽅面的差异,
    key的要求的差异,iterator及遍历顺序的差异,性能的差异。

1.6 unordered_xxx的哈希相关接口

Buckets和Hash policy系列的接⼝分别是跟哈希桶和负载因⼦相关的接口,⽇常使用的角度我们不需要太关注,后⾯学习了哈希表底层,我们再来看这个系列的接⼝,一目了然。

http://www.cnnetsun.cn/news/38331.html

相关文章:

  • 全面测试QtSql操作PostgreSQL数据库时戳字段的行为
  • 7、深入探索 NCurses 键盘交互:功能与应用
  • 13、NCurses绘图与屏幕数据存储功能详解
  • Apple Safari 26.2 发布 - macOS 专属浏览器 (独立安装包下载)
  • Microsoft System Center 2025 UR1 发布 - Windows 服务器管理软件
  • 从计划到报告:软件测试文档全流程精要
  • StarRocks 2.5.22 混合部署实战文档(CDH环境)
  • 14、深入探索RDF模板与树结构的应用
  • 20、数据到图形的转换:从 XSLT 到交互式可视化
  • Arkime YARA规则实战:构建企业级网络威胁检测体系
  • InfluxDbTemplate使用文档
  • Pyomo优化建模终极指南:从概念到实战应用
  • 开源客服系统终极指南:如何快速部署osTicket提升客户服务效率
  • Qsign签名API:Windows平台QQ机器人验证终极解决方案
  • 74.6%准确率刷新纪录:快手KAT-Dev-72B-Exp重构开源代码生成生态
  • jQuery Mobile滑块组件实战指南:解决移动端触控交互的5大痛点
  • 管家婆软件年结存后快马商城操作注意事项
  • DevToys开发工具箱完全手册:跨平台终极效率提升方案
  • 如何快速安装DiffSynth-Studio:AI视频生成的完整指南
  • shell脚本发邮件
  • 关系型数据库和非关系型数据库的区别
  • 网络安全中对称算法和非对称算法的作用和区别
  • Whisper-Tiny.en:5大商业场景揭秘2025智能语音市场新格局
  • 当工控老炮儿遇上上位机:手把手教你驯服大地控制器
  • 18. 有理函数和渐近线
  • 树莓派家庭服务器搭建指南从零到实用
  • 黑客大神都会玩这 10 个 Linux 命令,我不允许你还不知道!
  • Wi-Fi CERTIFIED Data Elements™ 技术概述
  • CTF — 压缩包密码爆破(非常详细),零基础入门到精通,看这一篇就够了
  • 基于YOLO的小目标检测增强:一种提升精度与效率的新框架