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

HashMap的基础用法(java)

Map<Integer, Integer> hashMap = new HashMap<>();
for (int num : nums) {hashMap.put(num, hashMap.getOrDefault(num, 0) + 1);
}

逐行详细解释:

  1. Map<Integer, Integer> hashMap = new HashMap<>();

    • 创建一个HashMap对象,用来存储键值对(key-value pairs)
    • 第一个Integer是键的类型(这里存储数组中的数字)
    • 第二个Integer是值的类型(这里存储每个数字出现的次数)
    • HashMap<>中的<>表示使用泛型,可以确保类型安全
  2. for (int num : nums)

    • 增强型for循环,遍历数组nums中的每一个元素
    • 每次循环,当前元素的值会被赋给变量num
  3. hashMap.put(num, hashMap.getOrDefault(num, 0) + 1);

    • 这是最核心的部分,完成统计功能
    • 拆解来看:
      • hashMap.getOrDefault(num, 0)
        • 尝试从hashMap中获取键为num的值(即该数字已出现的次数)
        • 如果num不存在于map中,则返回默认值0
      • ... + 1
        • 将获取到的值(已出现次数)加1
      • hashMap.put(num, ...)
        • num作为键,更新后的计数值作为值存入map中
        • 如果键已存在,会覆盖旧值;如果不存在,会新建一个条目

完整代码上下文

for (Map.Entry<Integer, Integer> entry : frequencyMap.entrySet()) {arr[i] = entry.getKey();     // 获取键(数组元素)count[i] = entry.getValue();  // 获取值(出现次数)i++;
}

逐部分解析

1. frequencyMap.entrySet()

  • ​作用​​:返回 Map 中所有键值对的集合(Set 集合)
  • ​返回值​​:是一个 Set<Map.Entry<Integer, Integer>> 类型的集合
  • ​特点​​:
    • 每个元素都是一个 Map.Entry 对象
    • Entry 是 Map 接口的内部接口,表示一个键值对

2. Map.Entry<Integer, Integer>

  • ​含义​​:表示 Map 中的一个键值对条目
  • ​泛型参数​​:
    • 第一个 Integer:键(key)的类型,这里是你数组中的数字
    • 第二个 Integer:值(value)的类型,这里是该数字出现的次数
  • ​常用方法​​:
    • getKey():获取该条目的键
    • getValue():获取该条目的值
    • setValue(V value):设置该条目的值

3. for 循环结构

  • ​类型​​:增强型 for 循环(foreach 循环)
  • ​工作方式​​:
    • 每次循环从 entrySet() 返回的集合中取出一个 Entry 对象
    • 赋给 entry 变量
    • 直到遍历完所有条目

4. 类比解释

可以把 frequencyMap 想象成一个字典:

  • entrySet() 相当于把字典中所有的"词条"(单词+解释)都拿出来
  • 每个 Entry 对象就是一个词条
    • getKey() 获取单词
    • getValue() 获取解释
  • foreach 循环就是依次查看每个词条

相关文章:

  • 系统性能分析基本概念(5) : 何时开始性能分析
  • Any类(C++17类型擦除,也称上帝类)
  • 【Java多线程】JUC其他常用组件
  • 系统架构设计(十八):ATAM
  • Linux的启动流程
  • Win11怎样禁止程序开机启动
  • vue3项目动态路由的相关配置踩坑记录
  • 每日算法 -【Swift 算法】Z 字形变换(Zigzag Conversion)详解与实现
  • 第二十章 TIM——基本定时器
  • Javascript 学习
  • leetcode2947. 统计美丽子字符串 I-medium
  • AGI大模型(32):LangChain实现RAG
  • 探秘 C++ 计数器类:从基础实现到高级应用
  • (Git) 稀疏检出(Sparse Checkout) 拉取指定文件
  • SpringCloud (3) 配置中心
  • 【AT32】 at32 软复位
  • 利用GeoTools实现导出MySQL地理数据表为shp格式
  • DHT11介绍
  • 对于Python虚拟环境的理解
  • YOLOv8模型剪枝笔记(DepGraph和Network Slimming网络瘦身)
  • 垡头做网站的公司/软文广告平台
  • 做网站不用tomcat行吗/各种网站
  • 天工网工程信息网官网/福建seo
  • wordpress建淘宝客网站吗/磁力bt种子搜索
  • 免费电子商务网站源码/常德政府网站市民留言
  • 北京网站建设方案书/网络广告名词解释