力扣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];
    }
}
相关推荐
tod1133 分钟前
力扣基础算法分类刷题:位运算、数学、数组与字符串详解
算法·leetcode·职场和发展
ValhallaCoder3 分钟前
hot100-图论
数据结构·python·算法·图论
熬了夜的程序员6 分钟前
【LeetCode】118. 杨辉三角
linux·算法·leetcode
智算菩萨8 分钟前
规模定律的边际递减与后训练时代的理论重构
人工智能·算法
小龙报8 分钟前
【51单片机】51 单片机 IIC 协议深度解析:时序实现 + GXHT3L 连续转换模式 + 数据解析
c语言·数据结构·stm32·单片机·嵌入式硬件·物联网·51单片机
kanhao1009 分钟前
电平交叉采样 (Level-Crossing Sampling)
算法·fpga开发·fpga
Hcoco_me9 分钟前
图像分割:目标检测、语义分割和实例分割
人工智能·深度学习·算法·目标检测·计算机视觉·目标跟踪
iAkuya9 分钟前
(leetcode)力扣100 69有效的括号(栈)
算法·leetcode·职场和发展
We་ct11 分钟前
LeetCode 21. 合并两个有序链表:两种经典解法详解
前端·算法·leetcode·链表·typescript
Epiphany.55616 分钟前
蓝桥杯2024年第十五届决赛真题-套手镯
c++·算法·蓝桥杯