146. LRU 缓存 --力扣 --JAVA

简介: ​请你设计并实现一个满足  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

 题目

请你设计并实现一个满足  LRU (最近最少使用) 缓存 约束的数据结构。

实现 LRUCache 类:

    • LRUCache(int capacity)正整数 作为容量 capacity 初始化 LRU 缓存
    • int get(int key) 如果关键字 key 存在于缓存中,则返回关键字的值,否则返回 -1
    • void put(int key, int value) 如果关键字 key 已经存在,则变更其数据值 value ;如果不存在,则向缓存中插入该组 key-value 。如果插入操作导致关键字数量超过 capacity ,则应该 逐出 最久未使用的关键字。

    函数 getput 必须以 O(1) 的平均时间复杂度运行。

    解题思路

      1. 由题可知,需要Map来存储数据,List可以通过通过控制添加到的索引位置来将数据提前;
      2. 对Map进行操作时,通过更新List涉及的数据;
      3. 溢出时从List获取末尾节点即最近最少使用的数据进行删除更新。

      代码展示

      class LRUCache {
          Map< Integer, Integer> lru = null;
          List<Integer> sort = null;
          int cap;
          public LRUCache(int capacity) {
              lru = new HashMap<>();
              sort = new ArrayList<>(capacity);
              cap = capacity;
          }
          public int get(int key) {
              Integer val = lru.get(key);
              if(val != null){
                  sort.remove((Integer) key);
                  sort.add(0, key);
                  return val;
              } else {
                  return -1;
              }
          }
          public void put(int key, int value) {
              if(lru.containsKey(key)){
                  lru.put(key,value);
                  sort.remove((Integer) key);
                  sort.add(0, key);
              } else {
                  if (lru.size() == cap) {
                      int last = sort.get(cap - 1);
                      sort.remove(cap - 1);
                      lru.remove(last);
                  }
                  lru.put(key, value);
                  sort.add(0, key);
              }
          }
      }

      image.gif


      目录
      相关文章
      |
      1月前
      |
      缓存 JavaScript 前端开发
      Java 如何确保 JS 不被缓存
      【10月更文挑战第19天】在 Java 中,可以通过设置 HTTP 响应头来确保 JavaScript 文件不被浏览器缓存。方法包括:1. 使用 Servlet 设置响应头,通过 `doGet` 方法设置 `Expires`、`Cache-Control` 和 `Pragma` 头;2. 在 Spring Boot 中配置拦截器,通过 `NoCacheInterceptor` 类和 `WebConfig` 配置类实现相同功能。这两种方法都能确保每次请求都能获取到最新的 JavaScript 内容。
      |
      1月前
      |
      缓存 算法 数据挖掘
      深入理解缓存更新策略:从LRU到LFU
      【10月更文挑战第7天】 在本文中,我们将探讨计算机系统中缓存机制的核心——缓存更新策略。缓存是提高数据检索速度的关键技术之一,无论是在硬件还是软件层面都扮演着重要角色。我们会详细介绍最常用的两种缓存算法:最近最少使用(LRU)和最少使用频率(LFU),并讨论它们的优缺点及适用场景。通过对比分析,旨在帮助读者更好地理解如何选择和实现适合自己需求的缓存策略,从而优化系统性能。
      48 3
      |
      1月前
      |
      缓存 分布式计算 NoSQL
      大数据-47 Redis 缓存过期 淘汰删除策略 LRU LFU 基础概念
      大数据-47 Redis 缓存过期 淘汰删除策略 LRU LFU 基础概念
      67 2
      |
      1月前
      |
      缓存 JavaScript 前端开发
      Java 如何确保 JS 不被缓存
      大家好,我是 V 哥。本文探讨了 Java 后端确保 JavaScript 不被缓存的问题,分析了文件更新后无法生效、前后端不一致、影响调试与开发及安全问题等场景,并提供了使用版本号、设置 HTTP 响应头、配置静态资源缓存策略和使用 ETag 等解决方案。最后讨论了缓存的合理使用及其平衡方法。
      |
      1月前
      |
      算法 Java
      LeetCode(一)Java
      LeetCode(一)Java
      消息中间件 缓存 监控
      122 0
      |
      3月前
      |
      缓存 NoSQL Java
      【Azure Redis 缓存 Azure Cache For Redis】Redis出现 java.net.SocketTimeoutException: Read timed out 异常
      【Azure Redis 缓存 Azure Cache For Redis】Redis出现 java.net.SocketTimeoutException: Read timed out 异常
      |
      3月前
      |
      缓存 算法 前端开发
      深入理解缓存淘汰策略:LRU和LFU算法的解析与应用
      【8月更文挑战第25天】在计算机科学领域,高效管理资源对于提升系统性能至关重要。内存缓存作为一种加速数据读取的有效方法,其管理策略直接影响整体性能。本文重点介绍两种常用的缓存淘汰算法:LRU(最近最少使用)和LFU(最不经常使用)。LRU算法依据数据最近是否被访问来进行淘汰决策;而LFU算法则根据数据的访问频率做出判断。这两种算法各有特点,适用于不同的应用场景。通过深入分析这两种算法的原理、实现方式及适用场景,本文旨在帮助开发者更好地理解缓存管理机制,从而在实际应用中作出更合理的选择,有效提升系统性能和用户体验。
      191 1
      |
      3月前
      |
      缓存 NoSQL 网络协议
      【Azure Redis 缓存】Redisson 连接 Azure Redis出现间歇性 java.net.UnknownHostException 异常
      【Azure Redis 缓存】Redisson 连接 Azure Redis出现间歇性 java.net.UnknownHostException 异常
      |
      3月前
      |
      缓存 前端开发 Java
      【Azure 应用服务】App Service 使用Tomcat运行Java应用,如何设置前端网页缓存的相应参数呢(-Xms512m -Xmx1204m)?
      【Azure 应用服务】App Service 使用Tomcat运行Java应用,如何设置前端网页缓存的相应参数呢(-Xms512m -Xmx1204m)?

      热门文章

      最新文章

      下一篇
      无影云桌面