news 2026/4/4 12:20:02

【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/3/20 12:16:21

jspm“众优”大学生家教平台的设计与实现(11824)

有需要的同学&#xff0c;源代码和配套文档领取&#xff0c;加文章最下方的名片哦 一、项目演示 项目演示视频 二、资料介绍 完整源代码&#xff08;前后端源代码SQL脚本&#xff09;配套文档&#xff08;LWPPT开题报告&#xff09;远程调试控屏包运行 三、技术介绍 Java…

作者头像 李华
网站建设 2026/4/3 5:12:39

生成式AI如何深度赋能高校信息化系统?

随着DeepSeek的开源发布,算力平权时代来临,人工智能部署及使用成本大大降低,诸多信息化层面原本难以实现或不敢想象的能力瞬间触手可及。像文本归纳、关键信息提取等任务,如今借助生成式人工智能可轻松完成。这为信息化系统升级迭代注入新活力,更为高校数字化转型发展道路…

作者头像 李华
网站建设 2026/3/27 3:29:18

Thinkphp和Laravel高校党支部党务管理系统_

目录 ThinkPHP与Laravel高校党支部党务管理系统对比摘要 项目开发技术介绍PHP核心代码部分展示系统结论源码获取/同行可拿货,招校园代理 ThinkPHP与Laravel高校党支部党务管理系统对比摘要 开发框架特性 ThinkPHP以轻量级、简单易学著称&#xff0c;适合快速开发中小型系统&am…

作者头像 李华
网站建设 2026/3/17 21:45:54

百度智能云上调2026年目标:增速提至200%,AI云开打系统战

新一轮AI云高强度竞争来了。 文&#xff5c;周享玥 赵艳秋 编&#xff5c;牛慧 数智前线获悉&#xff0c;百度智能云近日召开战略会&#xff0c;将2026年AI相关业务收入增速目标从100%上调至200%&#xff0c;并明确提出在AI云市场“全力抢第一”。这一调整向市场释放出清晰信…

作者头像 李华
网站建设 2026/4/2 21:13:24

AI-大语言模型LLM-Transformer架构2-自注意力

目的 为避免一学就会、一用就废&#xff0c;这里做下笔记 说明 本文内容紧承前文-Transformer架构1-整体介绍和注意力机制&#xff0c;欲渐进&#xff0c;请循序本文重点介绍Transformer架构中的自注意力机制&#xff08;Self-Attention&#xff09;&#xff0c;该机制在Tra…

作者头像 李华
网站建设 2026/4/3 5:46:55

SPA 技术支撑体系详解

本文详细介绍了单页应用(SPA)的技术支撑体系&#xff0c;涵盖核心框架、路由管理、状态管理、构建工具等关键技术。 主要内容包括&#xff1a; 1)主流前端框架(React/Vue)的SPA实现方案&#xff1b; 2)客户端路由管理原理与实现&#xff1b; 3)多种状态管理模式对比与最佳实践&…

作者头像 李华