原文:1. 两数之和(LeetCode 解题) - 每天一个JavaScript小知识@Js中文网 · 码农进阶题库

原文地址:https://www.javascriptc.com/interview-tips/zh_cn/leetcode/leetcode-javascript-solution-001/

题目描述:

难度:Easy

相关话题:数组哈希表

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

你可以假设每种输入只会对应一个答案。但是,你不能重复利用这个数组中同样的元素。

示例:

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

因为 nums[0] + nums[1] = 2 + 7 = 9
所以返回 [0, 1]
/**
 * @来源: Javascript中文网 - 前端进阶资源教程 https://www.javascriptc.com/
 * @介绍:一个致力于帮助开发者用代码改变世界为使命的平台,每天都可以在这里找到技术世界的头条内容
 * @param {number[]} nums
 * @param {number} target
 * @return {number[]}
 */
var twoSum = function(nums, target) {
  let hash={}
  for(let i=0;i<nums.length;i++){
    if(hash[nums[i]]!=null){
      return [hash[nums[i]],i]
    }
    hash[target-nums[i]]=i
  }
};
扩展阅读: