leetcode 1. 两数之和|刷题打卡

64 阅读1分钟

1. 两数之和

题目

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

你可以假设每种输入只会对应一个答案。但是,数组中同一个元素不能使用两遍。

给定 nums = [2, 7, 11, 15], target = 9

因为 nums[0] + nums[1] = 2 + 7 = 9 所以返回 [0, 1]

题解

暴力法

双重循环遍历所有情况判断是否等于 target

/**
 * @param {number[]} nums
 * @param {number} target
 * @return {number[]}
 */
var twoSum = function(nums, target) {
  for (let i = 0; i < nums.length - 1; ++i) {
    for (let j = i + 1; j < nums.length; ++j) {
      let t = nums[i] + nums[j];
      if (t === target) return [i, j];
    }
  }
};

空间复杂度:O(1) 时间复杂度:O(n²)

哈希表

遍历数组,用哈希表保存

key: 目标值 - 当前值
value: 当前值的索引

遍历的同时查看哈希表如果当前值存在 key 中返回结果

/**
 * @param {number[]} nums
 * @param {number} target
 * @return {number[]}
 */
var twoSum = function(nums, target) {
    let m=new Map();
    for(let i=0;i<nums.length;i++){
        if(m.get(target-nums[i])>=0){
            return [m.get(target-nums[i]),i];
        }else{
            m.set(nums[i],i);
        }
    }
};

时间复杂度: O(n)

空间复杂度: O(n)


  • 本文正在参与「掘金 2021 春招闯关活动」, 点击查看 活动详情