美文网首页
0001_Leetcode_1 两数之和【简单】

0001_Leetcode_1 两数之和【简单】

作者: 圆脸黑猫警长 | 来源:发表于2020-11-12 10:43 被阅读0次

命名规则:AAA_Leetcode_BBB XXX【YYY】 AAA表示第N篇,BBB表示Leetcode中的第N道题,XXX是标题,YYY是力扣中的难度等级。

万事开头难,从简单的开始

题目:

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

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

示例:
给定 nums = [2, 7, 11, 15], target = 9
因为 nums[0] + nums[1] = 2 + 7 = 9
所以返回 [0, 1]

解法一:穷举法

思路描述:最简单的方方法就是每个元素都都加一次去判断。

  for (let i = 0;i<nums.length;i++){
    let num1 = nums[i]
    for (let j = 0;j<nums.length;j++){
      let num2 = nums[j]
      if((num1 + num2 === target) && (i !== j)){
        return [i,j]
      }
    }
  }

这个代码还可以进一步优化,比如对于加法来说a+b和b+a是一样,那这样的遍历方式就有重复遍历的情况,第二个可优化为let j = i + 1,这样底下的i !==j也可以不写了。即使这样时间复杂度仍然是O(n²),空间复杂度是O(1)

解法二:查表法

思路描述:每遍历到一个元素就去记录一下,这样遍历下一个元素的时候就可以快速查找(记录要使用易查的方式,比如哈希表等,而不是用数组去记录,数组的特点是有序,但查找慢)

 const len = nums.length

  const map = new Map()
  map.set(target - nums[0],0)

  for(let i = 1;i<len;i++){
    const key = nums[i]
    const dif = map.get(key);
    if (dif !== undefined){
      return [dif,i]
    }else {
      map.set(target -nums[i] ,i)
    }
  }

这样的算法时间复杂度降到了O(n),空间复杂度是O(n),用空间换时间

相关文章

  • 0001_Leetcode_1 两数之和【简单】

    命名规则:AAA_Leetcode_BBB XXX【YYY】 AAA表示第N篇,BBB表示Leetcode中的第N...

  • 浅入浅出实现一个异步求和函数

    简化:两数之和 我们先来简单的实现一个异步两数之和函数 加深:多数之和 上面我们实现了两数之和,然后扩展到多数之和...

  • (简单)两数之和

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

  • 简单-两数之和

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

  • 两数之和(golang)

    原题:两数之和 关联:两数之和 II - 输入有序数组(golang)两数之和 IV - 输入 BST(golang)

  • 两数之和 II - 输入有序数组(golang)

    原题:两数之和 II - 输入有序数组 关联:两数之和(golang)两数之和 IV - 输入 BST(golan...

  • 两数之和,三数之和

    转载:https://www.cnblogs.com/DarrenChan/p/8871495.html 1. 两...

  • 两数之和&三数之和&四数之和&K数之和

    今天看了一道谷歌K数之和的算法题,忽然想起来之前在力扣上做过2、3、4数之和的题,觉得很有必要来整理一下。其实2、...

  • algrithrom

    求和问题,双指针解决 done 两数之和 三数之和 最接近三数之和 四数之和 链表反转问题 done 链表反转 链...

  • 简单算法之-两数之和

    给定一个整数数组和一个目标值,找出数组中和为目标值的两个数。你可以假设每个输入只对应一种答案,且同样的元素不能被重...

网友评论

      本文标题:0001_Leetcode_1 两数之和【简单】

      本文链接:https://www.haomeiwen.com/subject/grhftktx.html