【LeetCode笔记】146. LRU缓存机制(Java、双向链表、哈希表)

文章目录

  • 题目描述
  • 思路 & 代码
      • LinkedHashMap 的写法

题目描述

  • 大名鼎鼎的超高频面试题
  • 太感动,在这道题上花了太多时间了,今天终于补上博客了TvT
    在这里插入图片描述

思路 & 代码

  • 结构用的是:双向链表 + 哈希表。可以满足O(1)时间复杂度
  • put():key存在则delete,然后再put;否则直接put
  • get():key存在则保存值,然后put(放到前面,顺带删除原结点,复用代码)
  • 查找的O(1):通过HashMap实现,以及伪尾结点(removeLast)
  • 删除的O(1):通过双向链表实现
  • tips:伪头结点、伪尾结点(避免了检查相邻结点是否为null,不装入map)
class LRUCache {// 自己写双向链表结点类class DoubleListNode{int val;int key;DoubleListNode pre;DoubleListNode next;DoubleListNode(){}DoubleListNode(int keyy, int value){ key = keyy; val = value; }}int cap;int size;// 哈希表直接套用现成的 HashMapHashMap<Integer, DoubleListNode> map;// 使用伪头部、首部,便于省去判断DoubleListNode head,tail;public LRUCache(int capacity) {cap = capacity;size = 0;map = new HashMap();// 使用伪头部 & 伪首部:增删不用判断相邻为空// key和head、tail重复的情况怎么办:其实head和tail根本就没有放进map里head = new DoubleListNode();tail = new DoubleListNode();head.next = tail;tail.pre = head;}public int get(int key) {// 哈希查找O(1)DoubleListNode now = map.get(key);if(now != null){int getNum = now.val;// 把查找结点置于headput(now.key, now.val);return getNum;}return -1;}// 删尾 & 删中间兼容void removeNode(DoubleListNode removeN){size--;removeN.pre.next = removeN.next;removeN.next.pre = removeN.pre;// 记得把 map 的也删了~map.remove(removeN.key,removeN);}public void put(int key, int value) {// 更新的情况,删掉之前结点if(map.containsKey(key)){removeNode(map.get(key));}// 添加到headDoubleListNode nowN = new DoubleListNode(key, value);nowN.pre = head;nowN.next = head.next;head.next.pre = nowN;head.next = nowN;size++;// 记得加入 map~map.put(key,nowN);// Cache满,删除尾结点if(size > cap){removeNode(tail.pre);}}
}

LinkedHashMap 的写法

  • Java 自带的“外挂类”:维护插入顺序的哈希表
class LRUCache {private int cap;private Map<Integer, Integer> map = new LinkedHashMap<>();public LRUCache(int capacity) {this.cap = capacity;}public int get(int key) {if(map.keySet().contains(key)) {int value = map.get(key);map.remove(key);map.put(key, value);return value;}return -1;}public void put(int key, int value) {// Case 1: 重复插入,删除重复节点if(map.keySet().contains(key)) {map.remove(key);}// Case 2: 满了,删除第一个节点(LinkedHashMap 维护插入顺序)if(map.size() == cap) {Iterator<Map.Entry<Integer, Integer>> iterator = map.entrySet().iterator();iterator.next();iterator.remove();}map.put(key, value);}
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/504527.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

c语言random函数在vc,C++ 中随机函数random函数的使用方法

C 中随机函数random函数的使用方法一、random函数不是ANSI C标准&#xff0c;不能在gcc,vc等编译器下编译通过。 可改用C下的rand函数来实现。1、C标准函数库提供一随机数生成器rand&#xff0c;返回0&#xff0d;RAND_MAX之间均匀分布的伪随机整数。 RAND_MAX必须至少为32767。…

计算思维c语言软件,C语言编程入门与计算思维

课程概况This specialization is designed to let you explore computational thinking and beginning C programming topics, applying those concepts to develop solutions to a variety of practical problems.The first course assumes no programming experience, and th…

simulink和c语言开发,Simulink之嵌入式C代码生成-应用层和底层的接口

今天给大家带来的仍然是基于MBD的嵌入式代码生成&#xff0c;主要把应用层和底层接口之间的代码生成配置说一下。本周末会更新功能安全相关&#xff0c;欢迎大家留言交流&#xff01;作为一个总是用C写代码的人来说&#xff0c;第一次接触到基于MBD的代码生成的时候就迫不及待的…

【LeetCode笔记】215. 数组中的第K个最大元素(Java、快排、堆排、并发快排)

文章目录题目描述思路 & 代码快排基于 Fork / Join 的并发快排针对 topK 的快排优化堆排基本堆排结合题目的堆排二刷题目描述 大名鼎鼎的TOP K&#xff0c;主要考察排序快排 & 堆排 思路 & 代码 快排 没啥好说的&#xff0c;就是快排结束后&#xff0c;返回倒…

c语言中怎么画直线,ps如何画直线 【操作流程】

大家都知道电脑使用起来非常方便&#xff0c;但遇见ps如何画直线的时候就非常头疼了&#xff0c;如果你是第一次遇到ps如何画直线&#xff0c;怎么样才能快速解决ps如何画直线带来的烦恼呢&#xff1f;小编为大家收集了很多关于ps如何画直线问题的解决方法&#xff0c;下面请看…

【LeetCode笔记】470. 用Rand7()实现Rand10()(Java、概率)

文章目录题目描述代码 & 思路更新版三刷 - 极简版题目描述 貌似是比较高频的面试题目啊&#xff0c;有学概率论内味了&#xff08;讲道理我概率论学得不好&#xff09; 代码 & 思路 先用Rand7实现RandN&#xff08;N > 10&#xff09;&#xff0c;类似进制&…

【纠错记录】本地FTP服务器无法被外部连接

问题描述 在本地主机开了个FTP服务器&#xff0c;本机可以正常访问&#xff0c;但是外部主机不能访问FTP服务器 解决方法 ① 一开始以为是服务端Xlight FTP的问题&#xff0c;检查权限并没有发现问题 ② 接着考虑到有没有可能是客户端Flash FXP的问题&#xff0c;于是尝试直…

双线性插值算法c 语言实现,双线性插值 - CristianoC的个人空间 - OSCHINA - 中文开源技术交流社区...

前言最近在学习LBP&#xff0c;其中的圆形LBP特征由于计算的值可能不是整数&#xff0c;即计算出来的点不在图像上&#xff0c;我们要使用计算出来的点的插值点。目的的插值方法有很多&#xff0c;Opencv使用的是双线性插值&#xff0c;今天就来介绍一下双线性插值。概述先给大…

android 访问服务器josn文件,Android客户端对服务器回来的json文件进行解析

Android客户端对服务器返回的json文件进行解析和解析XML的方式大同小异&#xff0c;只有解析方式存在区别:/*** 解析服务器返回来的json数据* param content* return* throws Exception*/private static List parseJson(String content) throws Exception {List videoList new…

【LeetCode笔记】543. 二叉树的直径(Java、dfs、二叉树)

文章目录题目描述思路 & 代码题目描述 思路 & 代码 由这个结论考虑&#xff1a;直径中一定有一个父结点&#xff0c;那么当前直径长度就是&#xff1a; 当前父结点的左子树深度 右子树深度那么&#xff0c;只要遍历所有结点的最长直径值即可流程&#xff1a;在找每一…

【LeetCode笔记】461. 汉明距离(Java、位运算)

文章目录题目描述思路 & 代码更新版题目描述 既然是二进制&#xff0c;那就十有八九用位运算符既然是不同&#xff0c;那肯定用异或 思路 & 代码 两种方法&#xff0c;总体来说都是处理异或值方法一&#xff0c;转换成字符串&#xff0c;再遍历&#xff08;会慢一点…

android 启动服务同时传递数据,Android Studio开发基础之起动Service,并通过从Activity向Service传递数据...

Android Studio开发基础之启动Service&#xff0c;并通过从Activity向Service传递数据本实例演示启动Service&#xff0c;并通过从Activity向Service传递数据&#xff0c;新建一个Service&#xff0c;并敲如下代码&#xff1a;package com.example.lhb.startservice;import and…

android 自定义桌面图标大小设置,手机桌面图标尺寸可以改?OriginOS重新定义个性化...

原标题&#xff1a;手机桌面图标尺寸可以改&#xff1f;OriginOS重新定义个性化随着安卓定制化系统同质化情况的加重&#xff0c;越来越多的终端厂商开始探索一场新的变革。深耕手机领域的vivo&#xff0c;自然也察觉到了这一点。经过不断地努力和尝试之后&#xff0c;vivo终于…

【LeetCode笔记】347. 前K个高频元素(Java、优先队列、小顶堆、HashMap)

文章目录题目描述思路 & 代码更新版&#xff1a;引入 stream 流 Lambda题目描述 时间复杂度小于O(n*logn)&#xff0c;否则直接sort&#xff0c;再遍历就很轻松。很有学习价值的题目&#xff0c;第一次使用了优先队列PriorityQueue。 思路 & 代码 首先遍历数组&am…

signature=c0b9be9cdeb0a9e14dbbc8edc1d4c0e5,NRZ-PM-QPSK 16

摘要&#xff1a;We present a set of experiments of 16 100 Gb/s (1.6 Tb/s) coherent wavelength-division-multiplexing nonreturn-to-zero polarization-multiplexed quadrature phase-shift-keying transmission over installed standard single-mode fiber, probing dif…

CentOS 7.9 vmware workstation安装

https://mirrors.aliyun.com/centos/7.9.2009/isos/x86_64/CentOS-7-x86_64-Everything-2009.iso VMWare workstation 可以自动化安装这个版本的Linux&#xff0c;节省我很多时间。

【LeetCode笔记】240. 搜索二维矩阵II 剑指 Offer 04 二维数组中的查找(Java、指针)

文章目录题目描述思路 & 代码更新版题目描述 两道题一样的有序 搜索&#xff0c;明摆着二分查找但是比较懒…选取了题解里的指针做法 思路 & 代码 时间复杂度O(m n)&#xff0c;原理 & 思路 & 证明可见代码注释。代码很简单&#xff0c;主要是弄明白正确…

html中如何写平方根等,平方根的符号怎么打出来 电脑打字,平方根的符号怎样打出来?...

在WORD里面如何输入平方根“符号”&#xff1f;注&#xff1a;不是要公式&#xff0c;是要一个符号&#xff0c;最好回答时能打出来。方便下复制&#xff0c;哈哈用word域来完成&#xff0c;按下热键ctrlF9&#xff0c;然后输入 EQ \R(b,c)&#xff0c; 再按F9切换域代码即可&a…

【LeetCode笔记】238. 除自身以外数组的乘积(Java、思路题)

文章目录题目描述思路 & 代码更新版题目描述 首先暴力二层循环肯定可以&#xff0c;然后先累乘整个数组&#xff0c;再用除法肯定也行。但是很遗憾&#xff0c;两种做法都不满足题目说明。 思路 & 代码 O(n) & O(1)考虑到这个核心&#xff1a;ans[i] 就是当前元…

js在div中追加html,JS把内容动态插入到DIV的实现方法

/p>"http://www.w3.org/TR/xhtml11/DTD/xhtml11.dtd">Testingexample.js 文件内容&#xff1a;window.onload function() {var testdiv document.getElementById("testdiv");testdiv.innerHTML"I inserted this content.";}另一段代码&a…