题目链接:https://leetcode-cn.com/problems/two-sum
给定一个整数数组 nums 和一个整数目标值 target,请你在该数组中找出 和为目标值 target 的那 两个 整数,并返回它们的数组下标。
你可以假设每种输入只会对应一个答案。但是,数组中同一个元素在答案里不能重复出现。
1:字典模拟哈希,时间O(N), 空间O(N),
1)新建空字典,遍历列表,查看target - 当前数据 是否在字典中,在则返回当前索引和目标索引
2)不在,则把当前数据及其索引添加到字典中
class Solution:
def twoSum(self, nums: List[int], target: int) -> List[int]:
num_dict = dict()
for i, num in enumerate(nums):
if target - num in num_dict:
return [num_dict[target - num], i]
num_dict[nums[i]] = i
return []