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

题目一:两数之和

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

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

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

示例 1:

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

解释:因为 nums0 + nums1 == 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);
    } 
};
相关推荐
开源Z20 分钟前
LeetCode 42 · 接雨水:从暴力到双指针的三步优化
算法·leetcode
旖-旎29 分钟前
《LeetCode 695 岛屿的最大面积 FloodFill DFS 解法》
c++·算法·力扣·深度优先遍历·floodfill
影视飓风TIM43 分钟前
数据结构 | 链表超全笔记(单链表+双链表+高频算法题)
数据结构·笔记·链表
syagain_zsx1 小时前
STL 之 vector 讲练结合
c++·算法
牛油果子哥q1 小时前
STL set与map底层精讲,红黑树适配原理、有序去重特性、迭代器遍历、API实战与面试核心考点全解
开发语言·数据结构·c++·面试
MartinYeung52 小时前
[论文学习]DP2Unlearning:高效且具保证的大型语言模型遗忘框架(基于差分隐私的 LLM Unlearning 方法)
学习·算法·语言模型
Tian_Hang3 小时前
C++原型模式(Protype)
开发语言·c++·算法
bIo7lyA8v3 小时前
算法复杂度的渐进分析与实际运行时间的差异的技术8
算法
一切皆是因缘际会3 小时前
LLM轻量化联邦微调机理
数据结构·人工智能·数学建模·ai