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

[力扣146. LRU 缓存 ](https://leetcode.cn/problems/lru-cache/description/)

力扣146. LRU 缓存

使用LinkedHashmap(HashMap的子类,能够记住插入数据的顺序).
LRU是Lease Recently User的缩写,意思是最近 最少使用。比如设计一个文件缓存系统,每个文件有自己的大小和访问时间,文件缓存系统有总的大小,当往这个文件系统中放入新的文件时,如果发现超出文件缓存系统的容量,那么把访问时间最旧的文件删掉。
LRU实现代码如下

lass LRUCache {int cap;LinkedHashMap<Integer, Integer> cache = new LinkedHashMap<>();private void makeRecently(int key){int val = cache.get(key);//删除key,重新插入到队尾cache.remove(key);cache.put(key, val);// 删除 key,重新插入到队尾}public LRUCache(int capacity) {//初始化 LRU 缓存this.cap = capacity;}public int get(int key) {// 如果关键字 key 存在于缓存中,则返回关键字的值,否则返回 -1if(!cache.containsKey(key)){return -1;}makeRecently(key);//将key设置为最近使用return cache.get(key);}public void put(int key, int val) {//如果关键字 key 已经存在,则变更其数据值 value ;if(cache.containsKey(key)){cache.put(key, val);// 修改 key 的值makeRecently(key);// 将 key 变为最近使用return;}if(cache.size() >= this.cap){int oldestKey = cache.keySet().iterator().next();//链表头部就是最久未使用的keycache.remove(oldestKey);}cache.put(key,val);//将新的key添加到链表尾部}
}
http://www.lryc.cn/news/155709.html

相关文章:

  • Mysql存储引擎
  • 算法通关村-----数组实现加法专题问题解析
  • 倒排表的压缩算法
  • Android studio实现自定义圆形进度条 带刻度进度条 计步效果 时速表 水波纹效果
  • 使用【宝塔+docker】在云服务器上部署基于SpringBoot 和 Dubbo RPC 的项目:踩坑记录
  • 【算法与数据结构】617、LeetCode合并二叉树
  • ffmpeg把RTSP流分段录制成MP4,如果能把ffmpeg.exe改成ffmpeg.dll用,那音视频开发的难度直接就降一个维度啊
  • 朝夕光年游戏自动化测试实践
  • 数据结构基本概念
  • 【javaweb】学习日记Day9 - Mybatis 基础操作
  • Mybatis学习|Mybatis缓存:一级缓存、二级缓存
  • 230903文本docx
  • Mysql-DML(数据处理语言)
  • 部署项目至服务器
  • OSI与TCP IP各层的结构与功能,都有哪些协议
  • 【2023年11月第四版教材】第10章《进度管理》(第三部分)
  • 【Vuex状态管理】Vuex的基本使用;核心概念State、Getters、Mutations、Actions、Modules的基本使用
  • Linux centos7 bash编程(循环与条件判断)
  • 设计模式-6--装饰者模式(Decorator Pattern)
  • 质量属性案例-架构真题(二十一)
  • nacos Error to process server push response
  • 神经网络NLP基础 循环神经网络 LSTM
  • Oracle数据传输加密方法
  • Android列表片段
  • 【元宇宙】智能手机万岁
  • 华为mate60的发布代表着什么?有什么意义?
  • huggingface下载模型文件(基础入门版)
  • 在JS中tramsform与translate区别
  • ebay测评,物理环境与IP环境:解决平台风控问题的关键
  • 05-Redis