当前位置: 首页 > news >正文

【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方法高效处理最近访问标记和元素淘汰。

http://www.jsqmd.com/news/313839/

相关文章:

  • 神奇的环境变量
  • 基于Springboot+Vue的林业资源管理系统源码文档部署文档代码讲解等
  • 肝了整整90天!我把RK3588 Android开发做成了完整教程
  • 基于Springboot+Vue的旅游信息咨询网站的设计与实现源码文档部署文档代码讲解等
  • 基于Springboot+Vue的美食分享平台系统源码文档部署文档代码讲解等
  • 基于Springboot+Vue的民间救援队救助系统源码文档部署文档代码讲解等
  • 《P4035 [JSOI2008] 球形空间产生器》
  • “梦回汉唐”汉服商城网站的设计与实现(11823)
  • jspm“众优”大学生家教平台的设计与实现(11824)
  • 基于JSP的校园宿舍电费缴纳系统(11825)
  • “多鱼”旧物交易平台的设计与实现(11821)
  • “毛毛宠物店”宠物信息交流平台的设计与实现(11822)
  • Thinkphp和Laravel基于的农产品预售商城 平台设计_v8557农户_
  • 【GitHub项目推荐--Remotion Skills:AI代理技能框架】⭐⭐⭐
  • Thinkphp和Laravel日常办公用品打印机耗材商城直售推荐购物系统的设计与实现_02i27_
  • Thinkphp和Laravel汽车丢失车辆高速收费管理系统 车联网位置信息管理软件的设计与实现_
  • Thinkphp和Laravel物流仓储进销存信息运输管理系统_ho5g5_
  • 彻底告别 WinForms SOP 开发的“老大难”!
  • Thinkphp和Laravel基于Hadoop的高校固定资产租赁管理系统研究与实现_hot14_
  • Thinkphp和Laravel基于VUE敬老院管理系统养老院_35806vue
  • Thinkphp和Laravel基于Web的铁路火车票订票管理系统_w8iq4_
  • AI元人文:价值纠缠与规则涌现
  • 2026毕设ssm+vue旅游计划app论文+程序
  • 2026毕设ssm+vue旅游服务与管理论文+程序
  • 2026毕设ssm+vue旅游攻略网站系统论文+程序
  • 深入解析:芯谷科技--高效PWM控制降压型LED驱动器,点亮智能照明未来D3812
  • 2026最新日用香精品牌top5推荐!广东优质日用香精厂家助力高品质香氛体验
  • JAVA-SpringBoot、Spring框架以及SpringMVC学习总结
  • AI应用架构师主动学习实践:推动产业创新升级
  • 1.28假期记录