力扣1.两数之和(哈希表)

复制代码
class Solution {
    // 定义一个名为twoSum的方法,接收一个整数数组nums和一个整数target作为参数
    public int[] twoSum(int[] nums, int target) {
        // 创建一个HashMap,用于存储数组中的元素及其对应的索引
        Map<Integer, Integer> map = new HashMap<Integer, Integer>();
        // 遍历数组nums
        for (int i = 0; i < nums.length; i++) {
            // 检查map中是否存在一个键值对,其键为target减去当前元素的值
            if (map.containsKey(target - nums[i])) {
                // 如果存在这样的键值对,返回一个包含两个索引的数组
                return new int[]{map.get(target - nums[i]), i};
            }
            // 将当前元素及其索引添加到map中
            map.put(nums[i], i);
        }
        // 如果没有找到满足条件的两个数,返回一个空数组
        return new int[0];
    }
}
相关推荐
郭梧悠14 小时前
算法:有效的括号
python·算法·leetcode
atunet14 小时前
关于算法设计模式的演化与编程范式变迁的技术7
算法·设计模式
Jerry14 小时前
LeetCode 27. 移除元素
算法
旖-旎14 小时前
《LeetCode 1137 第N个泰波那契数 和 LeetCode 三步问题》
c++·算法·leetcode·动态规划
wabs66614 小时前
关于动态规划【力扣718.最长重复子数组的思考】
算法·leetcode·动态规划
技术小黑14 小时前
CNN算法实战系列08 | ResNeXt-50算法实战与猴痘病识别
人工智能·算法·cnn
Full Stack Developme14 小时前
Java 漏斗算法 及应用场景
java·开发语言·算法
atunet15 小时前
关于稀疏图结构的高效存储与遍历算法设计的技术7
算法
ysa05103015 小时前
【并查集】判环,深搜
数据结构·c++·算法·深度优先
Jerry15 小时前
LeetCode 704. 二分查找
算法