力扣_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
相关推荐
长安er4 小时前
LeetCode 102/103/513 二叉树层序遍历(BFS)三类经典题解题总结
数据结构·算法·leetcode·二叉树·bfs·层序遍历
java修仙传4 小时前
力扣hot100:搜索插入位置
算法·leetcode·职场和发展
韩凡15 小时前
HashMap的理解与结构
java·开发语言·哈希算法
自学小白菜18 小时前
每周刷题 - 第三周 - 双指针专题 - 02
python·算法·leetcode
杜子不疼.18 小时前
【LeetCode76_滑动窗口】最小覆盖子串问题
算法·哈希算法
不能只会打代码18 小时前
力扣--3433. 统计用户被提及情况
java·算法·leetcode·力扣
如竟没有火炬20 小时前
四数相加贰——哈希表
数据结构·python·算法·leetcode·散列表
埃伊蟹黄面21 小时前
模拟算法思想
c++·算法·leetcode
菜鸟233号1 天前
力扣654 最大二叉树 java实现
java·算法·leetcode