码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 无序容器unodered_map


    1、unordered_map;

    1. //unordered_map
    2. bool containsDuplicate(vector<int>& nums){
    3. unordered_map<int, bool> sub;
    4. for(auto i : nums){
    5. auto it = sub.find(i);
    6. if(it!=sub.end()&&it->second==true) return true;
    7. else sub[i]=true;
    8. }
    9. return false;
    10. }

    无序关联容器:unordered_set unordered_map unordered_multiset unordered_multimap;等使用键和哈希表,优点:快速读取数据;哈希函数将键转换为索引值,Hash; 无序关联容器接口类似于关联容器(有序),不同之处有:不需要lower_bound() 和 upper_bound();且常规关联容器是自动排序的且有大于小于等比较谓词,无序容器不存在;

    无序关联容器定义的类型

    类型 值 X::key_type Key,键类型,一般不应用; X::key_equal

    检查两个类型为key的参数是否相等;   

     unordered_map subm;
        cout<<"or:"<

    X::hasher 应用的hash函数,一个二元函数对象

    在c++11新标准中引入了unordered_set以及unordered_map,其背后是根据hash实现,而set、map等背后是根据RB_tree实现,在实现hash时,需要将数据转换为对应的hash码,放入对应的bucket中,所以这里的hash function是至关重要的, 如输出默认的hasher()函数生成的hash码:

    1. unordered_map<string, string> sample;
    2. // inserts key and elements
    3. sample.insert({ "ge", "ges" });
    4. // use of hash_function
    5. unordered_map<string, string>::hasher fn = sample.hash_function();
    6. cout << fn("ge") << endl;//既得获得的当前hash函数编码后的值;
    7. unordered_map<int, bool>::iterator it;
    8. sample.find(**)!=sample.end() 时在判断键值; it->first it->second;

    unordered_**中存放自定义的结构体时,就需要自己定义hash function;

    1. int maxArray(vector<int>&nums){
    2. int result=INT_MIN;
    3. int dp = 0;
    4. for(int i=0;isize();i++){
    5. dp = dp+nums[i];
    6. result = max(dp, result);
    7. if(dp<0)dp=0;
    8. }
    9. return result;
    10. }

  • 相关阅读:
    pgbackrest归档目录满,清理后写入仍报错,分析及处理
    codeigniter 4.1.3 gadget chain
    基于微信小程序+ JAVA后端实现的【微信小程序跑腿平台】设计与实现 (内附设计LW + PPT+ 源码+ 演示视频 下载)
    阿里云acp云计算认证考试科目有哪些?
    如何进行数据库的迁移与同步——【DBA 从入门到实践】第四期
    SQL面试常见问题总结指南
    【STM32】:GPIO工作原理
    跳跃游戏(贪心思想)
    【笔记篇】09仓管系统入库管理——之《实战供应链》
    中国互联网众筹行业
  • 原文地址:https://blog.csdn.net/ma1096539894/article/details/126678685
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号