LeetCode[两数之和] java版

java 复制代码
import java.util.HashMap;
import java.util.Map;

class Solution {
    public int[] twoSum(int[] nums, int target) {
        Map<Integer, Integer> map = new HashMap<>();
        for (int i = 0; i < nums.length; i++) {
            int diff = target - nums[i];
            if (map.containsKey(diff)) {
                return new int[] { map.get(diff), i };
            }
            map.put(nums[i], i);
        }
        return new int[] {}; // 理论上不会走到这,因为题目保证有解
    }
}

总结

  1. 哈希表是精髓

    它天然支持 数值 → 索引 的映射关系,用起来非常方便。

  2. 遍历时的操作

    • 对于当前数 num,先计算差值 diff = target - num

    • containsKey(diff) 判断哈希表里有没有这个"搭档"。

  3. 分两种情况

    • 如果有 → 说明答案找到了,直接返回 [map.get(diff), i]

    • 如果没有 → 把当前数存进哈希表,等后面的数来配对。

  4. 核心思想

    • 先查找,再存储,避免自己和自己配对。

    • 哈希表让查找和存储都变成 O(1),所以整体时间复杂度降为 O(n)

相关推荐
hipolymers9 分钟前
C语言怎么样?难学吗?
c语言·数据结构·学习·算法·编程
CS创新实验室29 分钟前
从“跑得动”到“跑得稳”:深度剖析数据结构究竟是理论点缀还是核心战力?
数据结构
jllllyuz1 小时前
MATLAB 蒙特卡洛排队等待模拟程序
数据结构·matlab
自我意识的多元宇宙2 小时前
树、森林——树、森林与二叉树的转换(森林转换为二叉树)
数据结构
海清河晏1112 小时前
数据结构 | 双循环链表
数据结构·链表
workflower2 小时前
机器人应用-楼宇室内巡逻
大数据·人工智能·算法·microsoft·机器人·动态规划·享元模式
ZPC82102 小时前
fanuc 机器人通过PR寄存器实现轨迹控制
人工智能·算法·计算机视觉·机器人
py有趣2 小时前
力扣热门100题之编辑距离
数据结构·算法·leetcode
Wave8452 小时前
C++继承详解
开发语言·c++·算法
睡觉就不困鸭2 小时前
第9天 两数之和
算法·哈希算法·散列表