news 2026/6/6 7:50:48

【LeetCode刷题】LRU缓存

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
【LeetCode刷题】LRU缓存

请你设计并实现一个满足 LRU (最近最少使用) 缓存 约束的数据结构。

实现LRUCache类:

  • LRUCache(int capacity)正整数作为容量capacity初始化 LRU 缓存
  • int get(int key)如果关键字key存在于缓存中,则返回关键字的值,否则返回-1
  • void put(int key, int value)如果关键字key已经存在,则变更其数据值value;如果不存在,则向缓存中插入该组key-value。如果插入操作导致关键字数量超过capacity,则应该逐出最久未使用的关键字。

函数getput必须以O(1)的平均时间复杂度运行。

示例:

输入["LRUCache", "put", "put", "get", "put", "get", "put", "get", "get", "get"] [[2], [1, 1], [2, 2], [1], [3, 3], [2], [4, 4], [1], [3], [4]]输出[null, null, null, 1, null, -1, null, -1, 3, 4]解释LRUCache lRUCache = new LRUCache(2); lRUCache.put(1, 1); // 缓存是 {1=1} lRUCache.put(2, 2); // 缓存是 {1=1, 2=2} lRUCache.get(1); // 返回 1 lRUCache.put(3, 3); // 该操作会使得关键字 2 作废,缓存是 {1=1, 3=3} lRUCache.get(2); // 返回 -1 (未找到) lRUCache.put(4, 4); // 该操作会使得关键字 1 作废,缓存是 {4=4, 3=3} lRUCache.get(1); // 返回 -1 (未找到) lRUCache.get(3); // 返回 3 lRUCache.get(4); // 返回 4

提示:

  • 1 <= capacity <= 3000
  • 0 <= key <= 10000
  • 0 <= value <=
  • 最多调用2 * 105getput

解题思路

  1. 数据结构选择OrderedDict既保留了哈希表的 O (1) 查找特性,又维护了元素的插入顺序,通过move_to_endpopitem可以在 O (1) 时间内完成「标记最近使用」和「淘汰最久未使用」的操作。
  2. get操作
    • 若 key 不存在,直接返回-1
    • 若 key 存在,将其移动到字典末尾(标记为「最近使用」),再返回对应值。
  3. put操作
    • 若 key 已存在,更新值并移动到末尾(标记为「最近使用」)。
    • 若 key 不存在,直接添加到末尾。
    • 若添加后超出容量,删除字典头部的元素(最久未使用的键)。

复杂度分析

  • 时间复杂度getput操作均为O(1),因为OrderedDictmove_to_endpopitem和哈希表的增删改查都是 O (1) 时间。
  • 空间复杂度O(capacity),最多存储capacity个键值对。

Python代码

from collections import OrderedDict class LRUCache: def __init__(self, capacity: int): self.cache = OrderedDict() self.capacity = capacity def get(self, key: int) -> int: if key not in self.cache: return -1 # 将访问的键移到末尾,表示最近使用 self.cache.move_to_end(key) return self.cache[key] def put(self, key: int, value: int) -> None: if key in self.cache: # 键已存在,更新值并移到末尾 self.cache.move_to_end(key) self.cache[key] = value # 检查容量,超出则删除最久未使用的键(头部元素) if len(self.cache) > self.capacity: self.cache.popitem(last=False) # ------------------------------ 测试驱动代码 ------------------------------ def run_operations(ops, params): """ 执行操作序列,返回每个操作的结果 :param ops: 操作类型列表(如["LRUCache", "put", "get"]) :param params: 对应每个操作的参数列表 :return: 操作结果列表,与题目输出格式一致 """ obj = None result = [] for op, param in zip(ops, params): if op == "LRUCache": obj = LRUCache(*param) result.append(None) elif op == "get": res = obj.get(*param) result.append(res) elif op == "put": obj.put(*param) result.append(None) return result # 题目示例输入 if __name__ == "__main__": ops = ["LRUCache","put","put","get","put","get","put","get","get","get"] params = [[2],[1,1],[2,2],[1],[3,3],[2],[4,4],[1],[3],[4]] # 执行并打印结果 output = run_operations(ops, params) print("输出结果:", output) # 验证是否与题目输出一致 expected = [None, None, None, 1, None, -1, None, -1, 3, 4] print("是否符合预期:", output == expected)

LeetCode提交代码

class LRUCache: def __init__(self, capacity: int): self.cache = OrderedDict() self.capacity = capacity def get(self, key: int) -> int: if key not in self.cache: return -1 # 将访问的键移到末尾,表示最近使用 self.cache.move_to_end(key) return self.cache[key] def put(self, key: int, value: int) -> None: if key in self.cache: # 键已存在,更新值并移到末尾 self.cache.move_to_end(key) self.cache[key] = value # 检查容量,超出则删除最久未使用的键(头部元素) if len(self.cache) > self.capacity: self.cache.popitem(last=False) # Your LRUCache object will be instantiated and called as such: # obj = LRUCache(capacity) # param_1 = obj.get(key) # obj.put(key,value)

程序运行截图展示

总结

本文介绍了LRU缓存机制的实现方法。通过使用Python的OrderedDict数据结构,既保证了O(1)时间复杂度的查找操作,又维护了元素的访问顺序。当缓存容量超出时,自动淘汰最久未使用的元素。该实现满足题目要求的get和put操作均为O(1)时间复杂度,并通过测试用例验证了正确性。关键点在于利用OrderedDict的move_to_end和popitem方法高效处理最近访问标记和元素淘汰。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/25 17:30:34

Thinkphp和Laravel基于的农产品预售商城 平台设计_v8557农户_

目录 设计思路技术架构功能模块安全与优化 项目开发技术介绍PHP核心代码部分展示系统结论源码获取/同行可拿货,招校园代理 设计思路 农产品预售商城平台基于ThinkPHP和Laravel框架开发&#xff0c;旨在连接农户与消费者&#xff0c;实现农产品的直接预售。平台设计围绕农户&am…

作者头像 李华
网站建设 2026/6/5 15:25:42

2026毕设ssm+vue旅游攻略网站系统论文+程序

本系统&#xff08;程序源码&#xff09;带文档lw万字以上 文末可获取一份本项目的java源码和数据库参考。系统程序文件列表开题报告内容一、选题背景关于旅游信息化管理问题的研究&#xff0c;现有研究主要以传统OTA平台整体架构为主&#xff0c;专门针对基于SSMVue技术栈的轻…

作者头像 李华
网站建设 2026/6/5 1:31:46

23.FPGA设计流程

1.设计准备 进行PCB设计前需要先明确PCB的功能和接口。 设计FPGA项目和设计PCB类似&#xff0c;只是设计对象是一块芯片的内部功能结构。 本质上讲&#xff0c;FPGA的设计&#xff0c;就是IC的设计。 在动手进行代码输入前必须明确IC的功能和对外接口。 2.设计输入 复杂的…

作者头像 李华
网站建设 2026/6/3 3:32:36

深度测评9个AI论文软件,助研究生轻松搞定学术写作!

深度测评9个AI论文软件&#xff0c;助研究生轻松搞定学术写作&#xff01; AI 工具如何重塑学术写作的未来 在当前的学术研究中&#xff0c;论文写作已成为研究生阶段不可或缺的一部分。随着人工智能技术的不断进步&#xff0c;越来越多的 AI 工具开始介入这一领域&#xff0c;…

作者头像 李华
网站建设 2026/5/21 10:16:46

《MYSQL技术内幕:InnoDB存储引擎》| 锁与事务

摘要&#xff1a;本篇聚焦 InnoDB 锁与事务核心机制&#xff0c;系统讲解了各种锁机制&#xff0c;解析脏读、不可重复读等并发问题及应对方案。同时深入剖析事务 ACID 特性的底层实现&#xff08;Redo Log、Undo Log&#xff09;、隔离级别差异。 第六章 锁 6.3 InnoDB 存储引…

作者头像 李华
网站建设 2026/6/7 2:40:54

AI-大语言模型LLM-Transformer架构3-嵌入和位置编码

目的 为避免一学就会、一用就废&#xff0c;这里做下笔记 说明 本文内容紧承前文-Transformer架构1-整体介绍和Transformer架构2-自注意力&#xff0c;欲渐进&#xff0c;请循序本文重点介绍Transformer架构中的嵌入和位置编码&#xff0c;它们在编码器堆栈和解码器堆栈中都…

作者头像 李华