C++ 容器中map和unordered map区别详解

 更新时间:2022年11月17日 16:01:46   作者:极智视界  
这篇文章主要为大家介绍了C++ 容器中map和unordered map区别示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪

C++ 中 map 和 unordered_map区别

map 和 unordered_map 都可以看做是一种 key-value 的映射关系,unordered_map 可以理解为 无序版的map。unordered_map 是在 C++11 标准才出现的,所以你在代码中如果使用了 unordered_map,则在编译的时候要使用 c++11及以后的标准 进行编译。

这里直击要点:

  • map 底层是 红黑树,(1) 增、删、改、查都是十分平稳的 log(n) 的复杂度,(2) 基于二叉查找树,数据是有序排列的 (按 key 排序)。在存储上 map 比较占用空间,因为在红黑树中,每一个节点都要额外保存父节点和子节点的连接,因此使得每一个节点都占用较大空间来维护红黑树的性质。
  • unordered_map 底层是 hash表, 其查找的复杂度是常数级别的 O(1),构造的时候如果有冲突时间成本会增加,并且做不到数据有序排列。冲突的解决:当冲突数小于8的时候用链式地址法解决冲突,当冲突大于8的时候使用红黑树解决冲突。

   来把区别用表格展示:

   map 和 unordered_map 在代码使用上十分类似,来看看两者的用法:

int main(){
  //// map 用法
  map<int, string> _ismap;
  // 增的三种方法
  _ismap.insert(make_pair(0, "kobe"));
  _ismap[1] = "james";
  _ismap.insert(map<int, string>::value_type(2, "curry"));
  // 遍历
  for (auto &iter : _ismap){
    cout << iter.first << " : " << iter.second << endl;
    /*
    * 输出如下 按key递增排序
    * 0 : kobe
    * 1 : james
    * 2 : curry
    */
  }
  // 删除
  map<int, string> ::iterator _mapIter = _ismap.find(0);
  _ismap.erase(_mapIter);    // 删除指定的key
  // _ismap.erase(0);  // 删除key=0的键值对
  // _ismap.erase(std::begin(_ismap));   // 删除第一个键值对
  //// unordered_map 用法
  unordered_map<int, string> _isunorderedMap;
  // 增的三种方法
  _isunorderedMap.insert(make_pair(0, "yaoming"));
  _isunorderedMap[1] = "yi";
  _isunorderedMap.insert(unordered_map<int, string>::value_type(2, "zhouqi"));
  // 遍历
  for (auto iter = unorderedMap.begin(); iter != unorderedMap.end(); iter++){
    cout << iter->first << " : " << iter->second << endl;
    /*
    * 输出如下 乱序
    * 2 : zhouqi
    * 0 : yaoming
    * 1 : yi
    */
    // 删除
    auto _unorderedIter = _isunorderedMap.find(0);
    _isunorderedMap.erase(_unorderedIter);     // 删除指定的key
    // _unorderedIter.erase(0);    // 删除key=0的键值对
    // _unorderedIter(_unorderedIter.begin());    // 删除第一个键值对
  }
}

以上就是C++ 容器中map和unordered map区别详解的详细内容,更多关于C++ map区别unordered map的资料请关注脚本之家其它相关文章!

相关文章

  • c/c++单例模式类的混合编译案例详解

    c/c++单例模式类的混合编译案例详解

    ​ 由于c语言中没有类的概念,因此对于有类的cpp文件与c文件混合编译时,提供一个中间层提供类的操作接口,在c文件中调用接口实现间接操作类对象,这篇文章主要介绍了c/c++单例模式类的混合编译的相关资料
    2022-10-10
  • 一文带你了解C++中queue的使用

    一文带你了解C++中queue的使用

    C++中的queue是一种容器,用于在FIFO(先进先出)原则下存储和管理元素。本篇文章将深入探讨C++中的queue,包括它的定义、使用、原理和示例,感兴趣的可以了解一下
    2023-04-04
  • 基于C语言实现扫雷小游戏

    基于C语言实现扫雷小游戏

    这篇文章主要为大家详细介绍了基于C语言实现扫雷小游戏,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-07-07
  • C++ 常量成员函数学习笔记

    C++ 常量成员函数学习笔记

    这篇文章主要为大家介绍了C++ 常量成员函数学习笔记,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-10-10
  • string,CString,char*之间的转化

    string,CString,char*之间的转化

    下面是MFC/C++/C中字符类型CString, int, string, char*之间的转换的说明与举例,经常用的东西,相信对于用C/C++的朋友,还是比较有用的
    2013-03-03
  • Qt利用QNetwork实现上传数据的示例代码

    Qt利用QNetwork实现上传数据的示例代码

    这篇文章主要为大家详细介绍了Qt如何利用QNetwork实现上传数据的 功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下
    2023-02-02
  • C++vector的insert函数用法小结

    C++vector的insert函数用法小结

    std::vector::insert是C++中用于在指定位置插入元素的函数,支持插入单个元素、多个相同元素、一个范围的元素或初始化列表中的元素,插入操作可能会使插入点之后的迭代器失效,并且时间复杂度为O(n),本文介绍C++vector的insert函数用法小结,感兴趣的朋友一起看看吧
    2025-03-03
  • QT连接SQLServer数据库的实现

    QT连接SQLServer数据库的实现

    要使用Qt连接SQL Server数据库,需要使用Qt提供的SQL模块和SQL Server驱动程序,具有一定的参考价值,感兴趣的可以了解一下
    2023-09-09
  • C++ 数据结构之对称矩阵及稀疏矩阵的压缩存储

    C++ 数据结构之对称矩阵及稀疏矩阵的压缩存储

    这篇文章主要介绍了C++ 数据结构之对称矩阵及稀疏矩阵的压缩存储的相关资料,这里实现稀疏矩阵和对称矩阵的压缩存储的实例,需要的朋友可以参考下
    2017-08-08
  • C语言的语法风格与代码书写规范指南

    C语言的语法风格与代码书写规范指南

    这篇文章主要介绍了C语言的语法风格与代码书写规范指南,文中主张了一些诸如变量和结构体的命名规范等细节方面的问题,需要的朋友可以参考下
    2016-02-02

最新评论