[算法] LeetCode 1.两数之和

Posted importgpx

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了[算法] LeetCode 1.两数之和相关的知识,希望对你有一定的参考价值。

LeetCode 1.两数之和(python)

1、朴素解法

最朴素的两个for循环大法:

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]

技术图片

但注意,不要用enumerate函数写,会超时:

class Solution:
    def twoSum(self, nums: List[int], target: int) -> List[int]:
        size = len(nums)
        for i, m in enumerate(nums):
            j = i+1
            while j < size :
                if nums[i] + nums[j] == target:
                    return [i, j]
                else:
                    j+=1

技术图片

2、用 in 优化(一遍for循环?)

python大法好:用in方法,只需要一个for循环就能解决问题了(但其实是python的in帮我们做了一个查找的循环)

class Solution:
    def twoSum(self, nums: List[int], target: int) -> List[int]:
        for i in range(len(nums)):
            if target-nums[i] in nums:
                if i != nums.index(target-nums[i]):
                    return [i, nums.index(target-nums[i])]

技术图片

3、用python字典(哈希表的算法思想)

class Solution:
    def twoSum(self, nums: List[int], target: int) -> List[int]:
        d = 
        for i in range(len(nums)):
            a = target - nums[i]
            if nums[i] in d:
                return d[nums[i]],i
            else:
                d[a] = i

技术图片

自己想想写写就明白了,字典d里键值对 k:v的含义是,与k能凑成target的值在nums中的位置为v。(即nums[i]=k时,nums[v]+num[i]=target。)
边在字典中记下互补这个位置(value)所需互补数(key)边遍历nums数组,之后的遇到nums[i]=之前记录的某个互补数时就是找到了,返回他的位置(value)和 i 就完成了。
技术图片

以上是关于[算法] LeetCode 1.两数之和的主要内容,如果未能解决你的问题,请参考以下文章

[算法] LeetCode 1.两数之和

LeetCode算法题——两数之和(python)

算法 Notes|LeetCode 1. 两数之和 - easy

每日算法/刷穿 LeetCode1. 两数之和(简单)

LeetCode算法1—— 两数之和

leetcode算法:1.两数之和