力扣146 LRU缓存 Java版本

embedded/2024/12/27 17:53:30/

文章目录

  • 题目描述
  • 代码


题目描述

请你设计并实现一个满足 LRU (最近最少使用) 缓存 约束的数据结构。
实现 LRUCache 类:
LRUCache(int capacity) 以 正整数 作为容量 capacity 初始化 LRU 缓存
int get(int key) 如果关键字 key 存在于缓存中,则返回关键字的值,否则返回 -1 。
void put(int key, int value) 如果关键字 key 已经存在,则变更其数据值 value ;如果不存在,则向缓存中插入该组 key-value 。如果插入操作导致关键字数量超过 capacity ,则应该 逐出 最久未使用的关键字。
函数 get 和 put 必须以 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 <= 105
最多调用 2 * 105 次 get 和 put

代码

java">import java.util.HashMap;class LRUCache {//模拟一个LRU的过程,如果还有空间就能直接放入新的内容,如果没有了就删除最近未使用的内容//需要一个map来完成获取键值对的操作,然后关于给这些键值对排序的话就可以想到队列,然后双向链表实现一个队列比较容易增删//实现一个链表class DLinkedNode {int key;int val;DLinkedNode prev;DLinkedNode next;DLinkedNode() {}DLinkedNode(int key, int val) {this.key = key;this.val = val;}}//用map来存储键值对,因为val存在链表的节点中,所以这个map的value存储链表节点就行了HashMap<Integer, DLinkedNode> map;int capacity;//这个表示最大的容量//声明虚拟头节点和尾节点来方便遍历和插入DLinkedNode dummyHead = new DLinkedNode();DLinkedNode dummyTail = new DLinkedNode();//这是一个初始化函数public LRUCache(int capacity) {this.capacity = capacity;map = new HashMap<>();dummyHead.next = dummyTail;dummyTail.prev = dummyHead;}public int get(int key) {//查找到一个元素之后就返回val,查找不到就返回-1//这里要考虑查找到之后就将刚才查找的元素往前提来满足最近使用排序if (map.containsKey(key)) {DLinkedNode node = map.get(key);DLinkedNode pre = node.prev;pre.next = node.next;node.next.prev = pre;tohead(node);return node.val;} else {return -1;}}private void tohead(DLinkedNode node) {//将当前节点排序到队列的头部node.next = dummyHead.next;dummyHead.next.prev = node;dummyHead.next = node;node.prev = dummyHead;}public void put(int key, int value) {//更新或者插入一个值//如果能找到就更新if (map.containsKey(key)) {DLinkedNode node = map.get(key);node.val = value;DLinkedNode pre = node.prev;pre.next = node.next;node.next.prev = pre;tohead(node);} else {//找不到就插入,插入的时候需要判断一下是否超过容量if (map.size() + 1 <= capacity) {DLinkedNode node = new DLinkedNode(key, value);map.put(key, node);tohead(node);} else {DLinkedNode node = removelast();map.remove(node.key);DLinkedNode newNode = new DLinkedNode(key, value);map.put(key, newNode);tohead(newNode);}}}private DLinkedNode removelast() {DLinkedNode node = dummyTail.prev;dummyTail.prev = dummyTail.prev.prev;dummyTail.prev.next = dummyTail;node.next = null;node.prev = null;return node;}
}/*** Your LRUCache object will be instantiated and called as such:* LRUCache obj = new LRUCache(capacity);* int param_1 = obj.get(key);* obj.put(key,value);*/

http://www.ppmy.cn/embedded/143206.html

相关文章

`pnpm` 不是内部或外部命令,也不是可运行的程序或批处理文件(问题已解决,2024/12/3

主打一个有用 只需要加一个环境变量 直接安装NodeJS的情况使用NVM安装NodeJS的情况 本篇博客主要针对第二种情况&#xff0c;第一种也可参考做法&#xff0c;当然眨眼睛建议都换成第二种 默认情况下的解决方法&#xff1a;⭐⭐⭐ 先找到node的位置&#xff0c;默认文件夹名字…

基于STM32设计的智能家居控制系统(华为云IOT)_275

文章目录 一、前言1.1 项目介绍【1】项目开发背景【2】设计实现的功能【3】项目硬件模块组成【4】设计意义【5】国内外研究现状【6】摘要1.2 设计思路1.3 系统功能总结1.4 开发工具的选择【1】设备端开发【2】上位机开发1.5 参考文献1.6 系统框架图1.7 系统原理图1.8 实物图1.9…

概率论——区间估计

置信区间&#xff1a; 概率分布中&#xff0c;抽出一些样本&#xff0c;通过某种方法&#xff0c;确定一个区间 求解思路&#xff1a; 1、定类型&#xff0c;摆公式 2、计算各分量 3、代入公式 例题&#xff1a; &#xff08;1&#xff09; 1、求μ&#xff0c;方差已知&…

Helm chart 配置、使用简介

helm说明 官方文档&#xff1a;https://helm.sh/zh/docs/helm/helm/ 关于 Helm Chart Helm是Kubernetes生态系统中的一个软件包管理工具&#xff0c;专门负责管理Kubernetes应用资源。而Helm仓库&#xff08;Repository&#xff09;在Helm中扮演着重要角色&#xff0c;是Hel…

初识交换机和路由器

目录 初识交换机和路由器交换机路由器主要区别工作流程如果是交换机&#xff1a;如果是路由器 初识交换机和路由器 左为路由器&#xff0c;右为交换机 交换机 交换机的前身是集线器&#xff0c;集线器是物理层的设备&#xff0c;有很多接口&#xff0c;当一台计算机A想发消息…

html-两个div,让一个div跟随另外一个div的高度

在开发的过程中遇到有些场景事这样的&#xff0c;两个div的高度不一致&#xff0c;而且都是动态高度&#xff0c;有的时候div1高&#xff0c;有的时候div2高&#xff0c;如果设置flex的话&#xff0c;那么就会把较矮的元素撑大&#xff0c;但是我想始终都以div1的高度作为基准&…

【Word 知识点】

快捷键 1.复制 Ctrlc 2.粘贴 Ctrlv 3.剪切 Ctrlx 4.全选 Ctrla 5.加粗 Ctrlb 6.打开 Ctrlo 7.新建 Ctrln 8.保存 Ctrls 9.查找 Ctrlf 10.替换 Ctrlh Word 要点 1.文档基本操作&#xff1a; 新建 打开 保存 复制 粘贴 剪切 查找 替换 2.字体&#xff1a;字体 字号 颜…

常见的 CSS 对齐方式介绍及代码示例

目录 常见的 CSS 对齐方式介绍及代码示例 1. 使用 text-align 属性对齐文本 2. 使用 vertical-align 对齐内联元素 3. 使用 margin 和 auto 实现水平居中 4. 使用 Flexbox 对齐 5. 使用 Grid 对齐 6. 使用 position 和 transform 对齐 常见的 CSS 对齐方式介绍及代码示例…