[leetcode]两数之和[javascript]

https://leetcode-cn.com/problems/two-sum/description/

描述

给定一个整数数组 nums和一个目标值 target,请你在该数组中找出和为目标值的那 两个 整数,并返回他们的数组下标。
你可以假设每种输入只会对应一个答案。但是,你不能重复利用这个数组中同样的元素。

示例:

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

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

分析

最容易想到的是两次循环

/**
 * @param {number[]} nums
 * @param {number} target
 * @return {number[]}
 */
var twoSum = function(nums, target) {
  if (!(nums instanceof Array)) {
    return 'ok'
  }
  var len = nums.length
  if (len < 2) {
    return 'ok'
  }
  for (var i = 0;i < len - 1;i++) {
    for (var j = 1; j < len; j++) {
      if (i === j) {
        continue
      }
      if (nums[i] + nums[j] === target) {
        return [i, j]
      }
    }
  }
  return []
};

看了解析知道可以把数组转换为哈希表处理。js中可以用对象来代替。
这样就不用嵌套循环了

/**
 * @param {number[]} nums
 * @param {number} target
 * @return {number[]}
 */
var twoSum = function(nums, target) {
  var arrobj = {}
  for (var i = 0;i < nums.length;i++) {
    var comp = target - nums[i]
    if (arrobj[comp] !== undefined) {
      return [arrobj[comp], i]
    }
    arrobj[nums[i]] = i
  }
  return []
};

再简化一点可以直接再转换对象的同时进行判断

/**
 * @param {number[]} nums
 * @param {number} target
 * @return {number[]}
 */
var twoSum = function(nums, target) {
  var arrobj = {}
  for (var i = 0;i < nums.length;i++) {
    var comp = target - nums[i]
    if (arrobj[comp] !== undefined) {
      return [arrobj[comp], i]
    }
    arrobj[nums[i]] = i
  }
  return []
};

相关链接

[leetcode]两数之和 II - 输入有序数组[javascript]

你可能感兴趣的:(leetcode)