Intervue featured on Shark TankIntervue featured on Shark Tank - mobile banner

Given an array of integers nums and an integer target, return indices of the two numbers such that they add up to target. You may assume that each input would have exactly one solution, and you may not use the same element twice. You can return the answer in any order.

Constraints:

  • 2 <= nums.length <= 10^4
  • -10^9 <= nums[i] <= 10^9
  • -10^9 <= target <= 10^9
  • Only one valid answer exists

Examples:

Input: [2, 7, 11, 15] and target = 9

Output: [0, 1]

Explanation: Because nums[0] + nums[1] == 2 + 7 == 9, we return [0, 1].

Solutions

Hash Table Approach

Time: O(n)Space: O(n)

We use a hash table to store the numbers we have seen so far and their indices. For each number, we check if its complement (target - number) is in the hash table. If it is, we return the indices of the complement and the current number. If not, we add the current number and its index to the hash table.

const twoSum = (nums, target) => {
  const map = new Map();

  for (let i = 0; i < nums.length; i++) {
    const complement = target - nums[i];

    if (map.has(complement)) {
      return [map.get(complement), i];
    }

    map.set(nums[i], i);
  }
};

Difficulty: Easy

Category: Hash Table

Frequency: Very High

Company tags:

AmazonGoogleFacebook