# 2 Sum

Given an array of integers, return indices of the two numbers such that they add up to a specific target.

You may assume that each input would have exactly one solution.

Example:

> nums = \[2, 7, 11, 15]\
> target = 9

returns

> \[0, 1]

because nums\[0] + nums\[1] = 2 + 7 = 9.

UPDATE (2016/2/13): The return format had been changed to zero-based indices. Please read the above updated description carefully.

{% tabs %}
{% tab title="Python" %}

```python
def twoSum(nums, target):
    """
    :type nums: List[int]
    :type target: int
    :rtype: List[int]
    """
    memo = {}
    for i in range(len(nums)):
        compliment = memo.get(nums[i])
        if compliment != None:
            return [compliment, i]
        memo[target-nums[i]] = i
```

{% endtab %}

{% tab title="Javascript" %}

```javascript
// @flow
const twoSum = (nums: ?number[], target: number) => {
  var memo: {
    [compliment: number]: number
  } = {}
  if (nums == null) return null;
  for (var i = 0; i < nums.length; i++) {
    if (memo[nums[i]] != null) {
      return [memo[nums[i]], i]
    }
    memo[target - nums[i]] = i
  }
}
```

{% endtab %}
{% endtabs %}


---

# Agent Instructions: Querying This Documentation

If you need additional information that is not directly available in this page, you can query the documentation dynamically by asking a question.

Perform an HTTP GET request on the current page URL with the `ask` query parameter:

```
GET https://blog.bernardw.com/problems/untitled.md?ask=<question>
```

The question should be specific, self-contained, and written in natural language.
The response will contain a direct answer to the question and relevant excerpts and sources from the documentation.

Use this mechanism when the answer is not explicitly present in the current page, you need clarification or additional context, or you want to retrieve related documentation sections.
