力扣_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
相关推荐
MQLYES13 分钟前
03-BTC-数据结构
数据结构·算法·哈希算法
im_AMBER36 分钟前
Leetcode 98 从链表中移除在数组中存在的节点
c++·笔记·学习·算法·leetcode·链表
不会c嘎嘎1 小时前
C++ 进阶:从理论到手撕 Unordered 系列容器(哈希表)
数据结构·哈希算法·散列表
漫随流水2 小时前
leetcode算法(429.N叉树的层序遍历)
数据结构·算法·leetcode·二叉树
漫随流水2 小时前
leetcode算法(116.填充每个节点的下一个右侧节点指针)
数据结构·算法·leetcode·二叉树
Jeremy爱编码3 小时前
leetcode热题组合总和
算法·leetcode·职场和发展
努力学算法的蒟蒻3 小时前
day57(1.8)——leetcode面试经典150
算法·leetcode·面试
元亓亓亓4 小时前
LeetCode热题100--5. 最长回文子串--中等
linux·算法·leetcode
千金裘换酒4 小时前
LeetCode 环形链表+升级版环形链表
算法·leetcode·链表
moxiaoran57534 小时前
Java使用Redis ZSet恢复用户能量
数据库·redis·哈希算法