-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy path001 Two Sum.py
More file actions
57 lines (46 loc) · 1.65 KB
/
001 Two Sum.py
File metadata and controls
57 lines (46 loc) · 1.65 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
"""
Given an array of integers, find two numbers such that they add up to a specific target number.
The function twoSum should return indices of the two numbers such that they add up to the target, where index1 must be
less than index2. Please note that your returned answers (both index1 and index2) are not zero-based.
You may assume that each input would have exactly one solution.
Input: numbers={2, 7, 11, 15}, target=9
Output: index1=1, index2=2
Author: Rajeev Ranjan
"""
class Solution:
def twoSum_TLE(self, num, target):
"""
built-in method .index
:param num: list
:param target: int
:return: tuple, (index1, index2)
"""
nums = num
for ind1, val in enumerate(nums):
try:
ind2 = nums.index(target - val)
return ind1+1, ind2+1
except ValueError:
continue
def twoSum_TLE_2(self, num, target):
nums = num
for ind1, val in enumerate(nums):
if target-val in nums:
return ind1+1, nums.index(target-val)+1
def twoSum(self, num, target):
"""
Hash Map
:param num: list
:param target: int
:return: tuple, (index1, index2)
"""
hash_map = {}
for ind, val in enumerate(num):
hash_map[val] = ind
for ind1, val in enumerate(num):
if target-val in hash_map:
ind2 = hash_map[target-val]
if ind1!=ind2:
return ind1+1, ind2+1
if __name__=="__main__":
print Solution().twoSum([3, 2, 4], 6)