1. 题目

设计并实现最不经常使用(LFU)缓存的数据结构。它应该支持以下操作:get 和 put。

  • get(key) - 如果键存在于缓存中,则获取键的值(总是正数),否则返回 -1。
  • put(key, value) - 如果键不存在,请设置或插入值。
  • 当缓存达到其容量时,它应该在插入新项目之前,使最不经常使用的项目无效。
  • 在此问题中,当存在平局(即两个或更多个键具有相同使用频率)时,最近最少使用的键将被去除。

进阶:
你是否可以在 O(1) 时间复杂度内执行两项操作?

示例:
LFUCache cache = new LFUCache( 2 /* capacity (缓存容量) */ );
cache.put(1, 1);
cache.put(2, 2);
cache.get(1);       // 返回 1
cache.put(3, 3);    // 去除 key 2
cache.get(2);       // 返回 -1 (未找到key 2)
cache.get(3);       // 返回 3
cache.put(4, 4);    // 去除 key 1
cache.get(1);       // 返回 -1 (未找到 key 1)
cache.get(3);       // 返回 3
cache.get(4);       // 返回 4

来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/lfu-cache
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

2. 解题

  • 类似题目:LeetCode 146. LRU缓存机制(哈希链表)
class node{public:int k, v, f;node(int key, int val, int freq):k(key),v(val),f(freq){}
};class LFUCache {unordered_map<int, list<node>::iterator> kPos;//key 对应的节点迭代器位置unordered_map<int, list<node>> freq_list;//不同的频数下挂着一条双链表,尾部是最少使用的int cap;int minfreq;//最小的频数int size;
public:LFUCache(int capacity) {cap = capacity;minfreq = 0;size = 0;}int get(int key) {if(kPos.find(key)==kPos.end())return -1;auto it = kPos[key];//找到对应的迭代器int f = it->f;int v = it->v;if(f == minfreq && freq_list[f].size() == 1)minfreq++;//最小的频数的节点只有1个,被移走了,最小频数+1freq_list[f].erase(it);//删除freq_list[++f].push_front(node(key,v,f));//新频数链表加入新节点kPos[key] = freq_list[f].begin();//记录迭代器位置return v;}void put(int key, int value) {if(kPos.find(key)!=kPos.end()){    //存在keyauto it = kPos[key];int f = it->f;if(f == minfreq && freq_list[f].size()==1)minfreq++;freq_list[f].erase(it);freq_list[++f].push_front(node(key,value,f));kPos[key] = freq_list[f].begin();}else if(size < cap)//不存在key,但还可插入{minfreq = 1;//新插入的只有1次freq_list[minfreq].push_front(node(key,value,1));kPos[key] = freq_list[1].begin();size++;}else if(cap != 0 && size == cap)//不存在key,且满了,且容量不为0{auto Node = freq_list[minfreq].back();int k = Node.k;freq_list[minfreq].pop_back();//频数最小的链表末尾的删除kPos.erase(k);//删除末尾key对应的迭代器size--;put(key, value);}}
};

228 ms 40 MB

LeetCode 460. LFU缓存(哈希双链表)相关推荐

  1. LeetCode 460. LFU 缓存 -- 哈希查询+双向链表

    LFU 缓存 困难 634 相关企业 请你为 最不经常使用(LFU)缓存算法设计并实现数据结构. 实现 LFUCache 类: LFUCache(int capacity) - 用数据结构的容量 ca ...

  2. ​ leetcode 460. LFU 缓存 hard​

    leetcode 460. LFU 缓存  hard 题目描述: 请你为 最不经常使用(LFU)缓存算法设计并实现数据结构. 实现 LFUCache 类: LFUCache(int capacity) ...

  3. 学习笔记 | LeetCode 460. LFU缓存

    LeetCode 460. LFU缓存 请你为 最不经常使用(LFU)缓存算法设计并实现数据结构.它应该支持以下操作:get 和 put. get(key)- 如果键存在于缓存中,则获取键的值(总是正 ...

  4. LeetCode 460. LFU缓存

    文章目录 题目描述 思路 实现 解法二 扩展 题目描述 实现一个LFU缓存(Least Frequently Used). 在需要移除元素时,移除最近访问频率最低的.可以对每个元素增加一个计数器,访问 ...

  5. Leetcode 460. LFU 缓存

    题目重述 请你为 最不经常使用(LFU)缓存算法设计并实现数据结构. 实现 LFUCache 类: LFUCache(int capacity) - 用数据结构的容量 capacity 初始化对象 i ...

  6. lfu算法c语言,LeetCode算法系列 460. LFU 缓存机制

    力扣原题 460. LFU 缓存机制 请你为 最不经常使用(LFU)缓存算法设计并实现数据结构. 实现 LFUCache 类:LFUCache(int capacity) - 用数据结构的容量 cap ...

  7. 460. LFU 缓存

    460. LFU 缓存 请你为 最不经常使用(LFU)缓存算法设计并实现数据结构. 实现 LFUCache 类: LFUCache(int capacity) - 用数据结构的容量 capacity ...

  8. 460.LFU 缓存

    请你为 最不经常使用(LFU)缓存算法设计并实现数据结构. 实现 LFUCache 类: LFUCache(int capacity) - 用数据结构的容量 capacity 初始化对象 int ge ...

  9. 力扣 460. LFU 缓存

    题目来源:https://leetcode.cn/problems/lfu-cache/ 大致题意: 设计一个 LFU 缓存类: LFUCache(int capacity) - 用数据结构的容量 c ...

最新文章

  1. android源代码 abi,Android内核源码Abi目录学习笔记
  2. pdf转ppt怎么转换,pdf转换ppt的方法分享
  3. redis优雅的批量删除key
  4. 制作一个表格,显示班级的学生信息。
  5. Java基本语法——(用于日后复习)
  6. SAP Spartacus的double maintenance -使用Cherrypick进行维护工作
  7. 漫画:什么是自动驾驶?
  8. 在linux上执行.net Console apps
  9. 分布式系统中的幂等设计
  10. 理解TCP/IP协议
  11. mysql innodb 读加锁,Mysql InnoDB加锁分析
  12. django mysql debug_django mysql db 日志无输出
  13. 金笛JDMAIL邮件系统办公管理—文件中转站
  14. 安利几个优秀的开源电商系统
  15. yar php使用,php中yar框架实例用法讲解
  16. 采访:新浪微博架构师兼首席PHP技术顾问惠新宸谈PHP的架构与发展
  17. 为什么现在的智能手机,都被设计成不可更换电池?
  18. 写一篇讲解优芽动画知识的教案
  19. JavaWeb核心技术系列教程(23)——JSP标签
  20. uni-app手机调试equest:fail abort

热门文章

  1. linux su切换用户提示Authentication failture的解决办法
  2. 下载java后缀的文件闪退_关于jarfile 打开闪退问题
  3. 关于.Net中Process和ProcessStartInfor的使用
  4. 字符设备驱动高级篇4——设备类(自动创建和删除设备文件)相关代码分析
  5. linux学习一个服务(未完)
  6. 【转】JMeter学习(十三)分布式部署
  7. 关于a标签不能调用js方法的小细节,你注意到了么?
  8. ios UIScrollView 基础属性
  9. The Power of Android Action Bars(转载)
  10. [转载]MVVM、MVVMLight、MVVMLight Toolkit之我见