美文网首页
1、两数之和 leetcode

1、两数之和 leetcode

作者: 九答 | 来源:发表于2020-04-01 11:04 被阅读0次

题目描述

describtion.png

思路:返回位置题中用python可以有两种方法,一种是位置遍历,返回i;另一种是用数组方法index。用后一种方法,要返回两个坐标时必须分开求,不然数字相同index只返回先出现的位置。先遍历, 在target减去i,在余下数组中求出另外一值

class Solution:
    def twoSum(self, nums: List[int], target: int) -> List[int]:
        for i in nums:
            j = target - i
            start_index = nums.index(i) + 1
            temp_nums = nums[start_index:]
            if j in temp_nums:
                return nums.index(i),start_index+temp_nums.index(j)
            

注意:这里的nums.index()如果两元素相同,则默认返回第一个。
优化:用hashmap。将数值和其在数组里的位置分别作为dict的key和value,比索引快。

        dict = {}
        for i in range(len(nums)):
            if target-nums[i] not in dict:
                dict[nums[i]] = i
            else:
                return [dict[target-nums[i]],i]

相关文章

网友评论

      本文标题:1、两数之和 leetcode

      本文链接:https://www.haomeiwen.com/subject/wpjouhtx.html