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,时间复杂度的优化无疑是质的提升。
  • 相关阅读:
    UITextView自适应高度解决方法
    UITextView自适应高度出现的问题
    UITextView出现的一些问题
    服务器终于好了!
    Update语句
    VS.NET经验与技巧
    唯一约束
    由C#风潮想起的-给初学编程者的忠告
    location.search在客户端获取Url参数的方法
    Web Services 入门概念
  • 原文地址:https://www.cnblogs.com/henryw/p/11643173.html
Copyright © 2011-2022 走看看