注意:哈希映射存储字符的顺序与压入的顺序不一样!!

例如:我想要将“leetcode”存放到哈希映射里面,那么存储顺序应该是 l e t c o d;
但是,输出的顺序是 d o l e t c

#include <iostream>
#include <unordered_map>

using namespace std;

int main()
{
   
    unordered_map<char, int> HashMap1;
    unordered_map<char, int> HashMap2;
    string s = "leetcode";
    for (int i = 0; i < s.size(); ++i)
    {
   
        HashMap1[s[i]] = i;
        if (HashMap2.count(s[i]) == 0)
        {
   
            HashMap2[s[i]] = i;
        }
    }
    for(auto j:HashMap1){
   
        cout<< j.first<<" ";
    }
    cout<<endl;
    for(auto j:HashMap2){
   
        cout<< j.first<<" ";
    }
    return 0;
}
CSDN博客搬运 文章被收录于专栏

CSDN博客搬运

全部评论

相关推荐

10-30 10:16
南京大学 Java
龚至诚:给南大✌️跪了
点赞 评论 收藏
分享
10-07 23:57
已编辑
电子科技大学 Java
八街九陌:博士?客户端?开发?啊?
点赞 评论 收藏
分享
昨天 18:54
门头沟学院 Java
点赞 评论 收藏
分享
点赞 收藏 评论
分享
牛客网
牛客企业服务