【LeetCode自用】LeetCode自用记录贴,题目一:两数之和

题目一:两数之和

题目内容:给定一个整数数组 nums 和一个整数目标值 target,请你在该数组中找出 和为目标值 target 的那 两个 整数,并返回它们的数组下标。

你可以假设每种输入只会对应一个答案,并且你不能使用两次相同的元素。

你可以按任意顺序返回答案。

示例 1:

复制代码
输入:nums = [2,7,11,15], target = 9
输出:[0,1]

解释:因为 nums[0] + nums[1] == 9 ,返回 [0, 1] 。

示例 2:

复制代码
输入:nums = [3,2,4], target = 6
输出:[1,2]

示例 3:

复制代码
输入:nums = [3,3], target = 6
输出:[0,1]

我这边提供一个非常非常小白的写法,代码如下:

typescript 复制代码
function twoSum(nums: number[], target: number): number[] {
    let targetList = [] as number[];
    for(let i = 0; i < nums.length;i ++) {
    		//先取第一个数
        let targetNum = nums[i];
        for( let j = i + 1; j< nums.length; j++) {
        //拿第一个数和其他数进行比较
            if(nums[i] + nums[j] === target) {
                targetList.push(i);
                targetList.push(j);
                return targetList;

            }
        }
    }
    return targetList;

};

然后有基础的就可以直接跳过上面的,看下面的

typescript 复制代码
function twoSum(nums: number[], target: number): number[] {
    // 两数之和: 经典简单哈希表
    const map = new Map();
    for(let i = 0; i < nums.length; i++) {
        // 计算需要的数
        const need = target - nums[i];
        // 判断是否已经储存有需要的数, 若有则获取并返回两数分别的索引
        if(map.has(need)) {
            return [i, map.get(need)];
        }
        // 每遍历过一个数, 储存入哈希表
        //  注意: 先尝试寻找需要的数, 再加入本数入哈希表, 避免重复使用某个数
        map.set(nums[i], i);
    } 
};
相关推荐
兰令水10 小时前
topcode【随机算法题】【2026.5.22打卡-java版本】
java·算法·leetcode
努力努力再努力wz10 小时前
【Redis入门系列】:Redis 内部编码机制与 String 深度解析:SDS 底层实现、三种编码与核心命令详解
c语言·开发语言·数据结构·数据库·c++·redis·缓存
Brilliantwxx10 小时前
【C++】 认识STL set与map(基础接口+题目OJ运用)
开发语言·数据结构·c++·笔记·算法
05候补工程师10 小时前
【线性代数】核心考点复习笔记:二次型配方法、施密特正交化步骤与特征值经典题型详解
经验分享·笔记·线性代数·考研·算法
Deep-w10 小时前
【MATLAB】基于遗传算法的直流电机 PI 控制器参数优化研究
开发语言·算法·matlab
海清河晏11110 小时前
数据结构 | 循环队列
数据结构·c++·visual studio
暴力求解10 小时前
数据结构---二叉树及堆的实现
数据结构·算法·二叉树
超梦dasgg11 小时前
并查集(Union-Find)详解 + Java 完整实现
java·数据结构·算法·图搜索
仍然.11 小时前
算法题目---队列+宽搜(BFS)
算法·宽度优先