HashMap的基础用法(java)

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中
        • 如果键已存在,会覆盖旧值;如果不存在,会新建一个条目

完整代码上下文

java 复制代码
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 循环就是依次查看每个词条
相关推荐
猫猫的小茶馆9 分钟前
【STM32】FreeRTOS 任务的删除(三)
java·linux·stm32·单片机·嵌入式硬件·mcu·51单片机
Hilaku11 分钟前
深入background-image:你可能不知道的几个性能优化与高级技巧
前端·css
南岸月明13 分钟前
副业自媒体1年终于明白:为什么会表达的人,能量越来越强,更能赚到钱?
前端
天天摸鱼的java工程师14 分钟前
🔧 MySQL 索引的设计原则有哪些?【原理 + 业务场景实战】
java·后端·面试
Danny_FD27 分钟前
Vue + Element UI 实现模糊搜索自动补全
前端·javascript
空影学Java31 分钟前
Day44 Java数组08 冒泡排序
java
gnip32 分钟前
闭包实现一个简单Vue3的状态管理
前端·javascript
斐济岛上有一只斐济37 分钟前
后端程序员的CSS复习
前端
Enddme40 分钟前
《面试必问!JavaScript 中this 全方位避坑指南 (含高频题解析)》
前端·javascript·面试
有梦想的程序员42 分钟前
微信小程序使用 Tailwind CSS version 3
前端