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)

相关推荐
君义_noip8 小时前
信息学奥赛一本通 1661:有趣的数列 | 洛谷 P3200 [HNOI2009] 有趣的数列
c++·算法·组合数学·信息学奥赛·csp-s
程序员:钧念8 小时前
深度学习与强化学习的区别
人工智能·python·深度学习·算法·transformer·rag
英英_9 小时前
MATLAB数值计算基础教程
数据结构·算法·matlab
一起养小猫9 小时前
LeetCode100天Day14-轮转数组与买卖股票最佳时机
算法·leetcode·职场和发展
hele_two9 小时前
快速幂算法
c++·python·算法
l1t10 小时前
利用DeepSeek将python DLX求解数独程序格式化并改成3.x版本
开发语言·python·算法·数独
jllllyuz10 小时前
基于子集模拟的系统与静态可靠性分析及Matlab优化算法实现
算法·matlab·概率论
程序员-King.10 小时前
day143—递归—对称二叉树(LeetCode-101)
数据结构·算法·leetcode·二叉树·递归
BlockChain88810 小时前
字符串最后一个单词的长度
算法·go
爱吃泡芙的小白白10 小时前
深入解析:2024年AI大模型核心算法与应用全景
人工智能·算法·大模型算法