zoukankan      html  css  js  c++  java
  • 1. 两数之和

    nums = [3, 2, 4]

    1. 暴力解法

    class Solution:
        def twoSum(self, nums, target=int):
            for i in range(len(nums)):
                res = target - nums[i]
                for j in range(i + 1, len(nums)):
                    if res == nums[j]:
                        return [i, j]
    
    • 这种方法最直观明了,这样也往往意味着高时间复杂度,此时的时间复杂度为 O(n2)

    2. 使用字典

    class Solution2:
        def twoSum(self, nums, target=int):
            hashmap = {}
            for i, v in enumerate(nums):
                hashmap[v] = i
            for i, v in enumerate(nums):
                j = hashmap.get(target - v)
                if j and i != j:
                    return [i, j]
    
    • python中的dict数据类型,采用的就是哈希表实现的,此时时间复杂度为 O(n) + O(n)即 O(n)。
    • 仔细观察,方法2我们很容易发现,使用了两次for循环,而且for循环的作用很单一,这就让我们联想到能不能减少一次for循环呢?
    • 以下就是进一步优化后的代码。

    3. 进一步优化

    class Solution3:
        def twoSum(self, nums, target):
            hashmap = {}
            for i, num in enumerate(nums):
                if hashmap.get(target - num) is not None:
                    return [i, hashmap.get(target - num)]
                hashmap[num] = i
    
    • 方法3只是在方法2的基础上减少了一次for循环,相当于之前的 2O(n2)的时间复杂度的常数去掉了,优化程度是有限的。
    • 此时相较于方法1,时间复杂度的优化无疑是质的提升。
  • 相关阅读:
    restframework 自定义返回响应格式
    restframework 分页器
    Python设计模式
    Pytest系列
    Pytest系列
    Pytest系列 -pytest-dependency 用例依赖
    restframework jwt登录验证
    restframework 自定义json返回格式
    Axure RP8 注册码
    LVM 移除PV步骤
  • 原文地址:https://www.cnblogs.com/henryw/p/11643173.html
Copyright © 2011-2022 走看看