460 LFU 缓存
本文最后更新于:2022年4月9日 中午
请你为 最不经常使用(LFU)缓存算法设计并实现数据结构。
实现 LFUCache 类:
LFUCache(int capacity)- 用数据结构的容量capacity初始化对象int get(int key)- 如果键存在于缓存中,则获取键的值,否则返回 -1。void put(int key, int value)- 如果键已存在,则变更其值;如果键不存在,请插入键值对。当缓存达到其容量时,则应该在插入新项之前,使最不经常使用的项无效。在此问题中,当存在平局(即两个或更多个键具有相同使用频率)时,应该去除 最久未使用 的键。
注意「项的使用次数」就是自插入该项以来对其调用 get 和 put 函数的次数之和。使用次数会在对应项被移除后置为 0 。
进阶:
- 你是否可以在 O(1) 时间复杂度内执行两项操作?
示例:
1 | |
提示:
0 <= capacity, key, value <= 104- 最多调用
105次get和put方法
Solution
参考题解:@王尼玛
两个哈希表 + N个双链表
key-node 哈希表、freq-LinkedList 哈希表
1 | |
本博客所有文章除特别声明外,均采用 CC BY-SA 4.0 协议 ,转载请注明出处!