欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

初了解map和unordered_map

程序员文章站 2022-06-02 22:57:38
...

初了解map和unordered_map简单差别使用

1.需要引用的头文件不同
map:#include
unordered_map<unordered_map>
2.
map含义:
内部实现一个红黑树(红黑树是非严格平衡二叉搜索树,而AVL是严格平衡二叉搜索树),红黑树具有自动排序的功能,因此map内部的所有元素都是有序的,红黑树的每一个节点都代表着map的一个元素。因此,对于map进行的查找,删除,添加等一系列的操作都相当于是对红黑树进行的操作。map中的元素是按照二叉搜索树(又名二叉查找树、二叉排序树,特点就是左子树上所有节点的键值都小于根节点的键值,右子树所有节点的键值都大于根节点的键值)存储的,使用中序遍历可将键值按照从小到大遍历出来。
unordered_map含义:
内部实现了一个哈希表(也叫散列表,通过把关键码值映射到Hash表中一个位置来访问记录,查找的时间复杂度可达到O(1),其在海量数据处理中有着广泛应用)。因此,其元素的排列顺序是无序的。
map:
1)优点有序性,这是map结构最大的优点,其元素的有序性在很多应用中都会简化很多的操作。
2)缺点, 空间占用率高,因为map内部实现了红黑树,虽然提高了运行效率,但是因为每一个节点都需要额外保存父节点、孩子节点和红/黑性质,使得每一个节点都占用大量的空间
3)适用:对于那些有顺序要求的问题,用map会更高效一些

unordered_map:
1)优点: 因为内部实现了哈希表,因此其查找速度非常的快
2)缺点: 哈希表的建立比较耗费时间
3)适用:适用处:对于查找问题,unordered_map会更加高效一些。

Leetcode刷题遇到的所以打算记一下
初了解map和unordered_map

class Solution {
public:
    int romanToInt(string s) {
        unordered_map<char,int>mmp;
        mmp['I']=1;
        mmp['V']=5;
        mmp['X']=10;
        mmp['L']=50;
        mmp['C']=100;
        mmp['D']=500;
        mmp['M']=1000;
        int sum=0;
        int num=0;
        for(int i=0;i<=s.size()-1;i++)
        {
            if(mmp[s[i]]<mmp[s[i+1]])
            sum+=-mmp[s[i]];
            else
            num+=mmp[s[i]];
        }
         return sum+num;
    }
};

自以为的map的用法:
第一种:变量名[‘x’]=xx;
第二种:map<l类型,类型>变量名={{‘x’,x},
{‘c’,c},
{‘z’,z}};

相关标签: 学习总结