LeetCode-1 两数之和

1. 题目

https://leetcode-cn.com/problems/two-sum/

给定一个整数数组 nums 和一个目标值 target,请你在该数组中找出和为目标值的那 两个 整数,并返回他们的数组下标。

你可以假设每种输入只会对应一个答案。但是,你不能重复利用这个数组中同样的元素。

示例:

给定 nums = [2, 7, 11, 15], target = 9

因为 nums[0] + nums[1] = 2 + 7 = 9
所以返回 [0, 1]

2. 我的AC

推算一遍

i = 0, num = 2
dic[9-2] = 0, {7:0} # 7的match位在0处

i = 1, num = 7
return [0, 1]

----
i = 2, num = 11
dic[9-11] = 0, {-2:2}

i = 3, num = 15
dic[9-15] = 0, {-6:3}
class Solution(object):
    def twoSum(self, nums, target):
        """
        :type nums: List[int]
        :type target: int
        :rtype: List[int]
        """
        dic = {}
        for i, num in enumerate(nums):
            if num in dic:
                return [dic[num], i]
            else:
                dic[target - num] = i

3. 小结

  1. 看到精练的代码不理解,可以按照程序一步步推演一遍,推完就懂了

你可能感兴趣的:(LeetCode-1 两数之和)