力扣_day1

两数之和

hash表的时间复杂度为什么是O(1)?

hash表是基于数组+链表的实现的。数组在内存中是一块连续的空间,只要知道查找数据的下标就可快速定位到数据的内存地址,即数组查找数据的时间复杂度为O(1)。

能用一次循环解决问题就用一次循环。

python 复制代码
class Solution(object):
    def twoSum(self, nums, target):
        """
        :type nums: List[int]
        :type target: int
        :rtype: List[int]
        """
        has = {}
        for i in range(len(nums)):
            key = target - nums[i]
            if key in has:
                return i, has[key]
            has[nums[i]] = i
相关推荐
ZHE|张恒4 小时前
LeetCode - 寻找两个正序数组的中位数
算法·leetcode
_dindong4 小时前
【递归、回溯、搜索】专题六:记忆化搜索
数据结构·c++·笔记·学习·算法·深度优先·哈希算法
努力学算法的蒟蒻5 小时前
day03(11.1)——leetcode面试经典150
java·算法·leetcode
im_AMBER6 小时前
Leetcode 43
笔记·学习·算法·leetcode
mifengxing6 小时前
力扣每日一题——接雨水
c语言·数据结构·算法·leetcode·动态规划·
小南家的青蛙8 小时前
LeetCode LCR 085 括号生成
算法·leetcode·职场和发展
夜晚中的人海8 小时前
【C++】模拟算法习题
c++·算法·哈希算法
晨非辰9 小时前
《数据结构风云》递归算法:二叉树遍历的精髓实现
c语言·数据结构·c++·人工智能·算法·leetcode·面试