给定一个整数数组 nums 和一个目标值 target,请你在该数组中找出和为目标值的那 两个 整数,并返回他们的数组下标。
你可以假设每种输入只会对应一个答案。但是,你不能重复利用这个数组中同样的元素。
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/two-sum
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
————————————
(1)暴力解法:
class Solution:
def twoSum(self, nums: List[int], target: int) -> List[int]:
for i in range(len(nums)):
for j in range(i+1,len(nums)):
if nums[i] + nums[j] == target:
return [i,j]
return []
(2)用字典存放前面每一个待拟合的余数:
class Solution:
def twoSum(self, nums: List[int], target: int) -> List[int]:
dicts = {}
for index,num in enumerate(nums):
ans = target - num
if num in dicts.keys(): # 注意这里使用num拟合keys()值,而不是ans
return [dicts[num],index]
else:
dicts[ans] = index
return []