LeetCode:LRU 缓存机制
题目
前言:
推荐官方题解:https://leetcode-cn.com/problems/lru-cache/solution/lruhuan-cun-ji-zhi-by-leetcode-solution/
注:对高性能的 LRU 理解,会有一定提升作用
运用你所掌握的数据结构,设计和实现一个 LRU
(最近最少使用) 缓存机制 。
实现 LRUCache
类:
LRUCache(int capacity)
以正整数作为容量capacity
初始化 LRU 缓存- · 如果关键字
key
存在于缓存中,则返回关键字的值,否则返回-1
。 void put(int key, int value)
如果关键字已经存在,则变更其数据值;如果关键字不存在,则插入该组「关键字-值」。当缓存容量达到上限时,它应该在写入新数据之前删除最久未使用的数据值,从而为新的数据值留出空间。
进阶: 你是否可以在 O(1)
时间复杂度内完成这两种操作?
示例:
1 | 输入 |
提示:
1 <= capacity <= 3000
0 <= key <= 3000
0 <= value <= 10^4
- 最多调用
3 * 104
次get
和put
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/lru-cache
代码
Go
如下题解:性能无官方性能优。
1 | package main |