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

146.LRU缓存

146. LRU 缓存

使用哈希表和双向链表解决(也可以LinkedHashMap)

用于操作链表的方法为removeNode, addToHead.

在put中:

        如果不存在key,则为添加, ++size, 需要判断容量;

                容量超过,则尾删, --size;

                容量没超过, 则不删;

        如果存在key, 则为修改, 不需要判断容量;

以上两步均为操作,因此都得addToHead.

class Node{
    public int key, val;
    public Node prev;
    public Node next;
    public Node(int a, int b){
        this.key = a;
        this.val = b;
        this.prev = null;
        this.next = null;
    }
    public Node(){
        this.key = 0;
        this.val = 0;
        this.prev = null;
        this.next = null;
    }
}
class LRUCache {
    private Node head;
    private Node tail;
    private Map<Integer, Node>map = new HashMap<>();
    private int capacity;
    private int size;
    public LRUCache(int capacity) {
        this.size = 0;
        this.capacity = capacity;
        head = new Node();
        tail = new Node();
        head.next = tail;
        tail.prev = head;
    }
    
    public int get(int key) {
        if(!map.containsKey(key)){
            return -1;
        }
        Node temp = map.get(key);
        removeNode(temp);
        addToHead(temp);
        return temp.val;
    }
    
    public void put(int key, int value) {
        Node node = map.get(key);
        if(node == null){
            Node newNode = new Node(key, value);
            map.put(key, newNode);
            addToHead(newNode);
            ++size;
            if(size > capacity){
                Node tail1 = tail.prev;
                map.remove(tail1.key);
                removeNode(tail1);
                --size;
            }
        }else {
            node.val = value;
            removeNode(node);
            addToHead(node);
        }
    }

    public void removeNode(Node node){
        node.next.prev = node.prev;
        node.prev.next = node.next;
    }

    public void addToHead(Node node){
        node.next = head.next;
        node.prev = head;
        head.next = node;
        node.next.prev = node;
    }
}

先前我在实现put操作时使用了containsKey,这使得我原来的代码时间消耗很高


http://www.kler.cn/a/575958.html

相关文章:

  • (二十三)Java-synchronized
  • 基于Docker去创建MySQL的主从架构
  • DeepSeek × 豆包深度整合指南:工作流全解析
  • vue管理布局左侧菜单栏NavMenu
  • 蓝桥备赛(11)- 数据结构、算法与STL
  • 在 MySQL 的默认事务隔离级别(可重复读,REPEAT READ)下,事务 A 和事务 B 对同一行数据的操作时会产生什么呢?
  • “此电脑”中删除WPS云盘方法(百度网盘通用)
  • C++的基础(类)练习
  • Modbus TCP转Profibus DP协议转换网关赋能玻璃生产企业设备协同运作
  • nginx简单命令启动,关闭等
  • 嵌入式 ARM Linux 系统构成(3):根文件系统(Root File System)
  • 【Java代码审计 | 第十篇】命令执行漏洞成因及防范
  • HTML页面中divborder-bottom不占用整个底边,只占用部分宽度
  • HTML5的新特性有哪些?
  • 【第22节】C++设计模式(行为模式)-Iterator(迭代器)模式
  • 深入解析MySQL MVCC实现机制:从源码到实战演示隔离级别原理
  • RSA的理解运用与Pycharm组装Cryptodome库
  • Java8——Lambda表达式,常见的内置函数式接口
  • python学习笔记-day4(解决实际问题)
  • 如何查看Elastic-Job在Zookeeper中的注册信息