LeetCode:146LRU缓存

java 复制代码
class LRUCache {

    //定义双向链表的节点结构
    class Node{
        int key;
        int value;
        Node prev;
        Node next;
        public Node(){};
        public Node(int key, int value){
            this.key = key;
            this.value = value;
        }
    }

    private Map<Integer,Node> cache = new HashMap<>();
    private int capacity;
    private int size;
    //头尾节点
    private Node head,tail;

    public LRUCache(int capacity) {
        this.capacity = capacity;
        this.size = 0;
        //初始化头尾
        head = new Node();
        tail = new Node();
        head.next = tail;
        tail.prev = head;
    }
    //获取
    public int get(int key){
        Node node = cache.get(key);
        if(node == null){
            return -1;
        }
        moveToHead(node);
        return node.value;
    }
    //放入/更新
    public void put(int key, int value){
        Node node = cache.get(key);

        if(node == null){
            //全新的数据
            Node newNode = new Node(key,value);
            cache.put(key,newNode);
            addToHead(newNode);
            size++;
            //判断是否已满
            if(size > capacity){
                Node tailNode = removeTail();
                cache.remove(tailNode.key);
                size--;
            }
        }else{
            //更新数据
            node.value = value;
            moveToHead(node);
        }
    }
    //将一个节点抽出来,插到最前面(现有节点)
    private void moveToHead(Node node){
        removeNode(node);
        addToHead(node);
    }
    //将一个节点从现有位置取出来
    private void removeNode(Node node){
        node.prev.next = node.next;
        node.next.prev = node.prev;
    }
    //放到最前面
    private void addToHead(Node node){
        node.prev = head;
        node.next = head.next;
        head.next.prev = node;
        head.next = node;
    }
    //逐出最久未使用的关键字
    private Node removeTail(){
        Node res = tail.prev;
        removeNode(res);
        return res;
    }
}

/**
 * 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);
 */

哈希表+双向链表的组合结构

写几个方法方便直接调用:

将一个节点直接插入到最前面的方法

将一个节点从当前位置取出来的方法

接节点抽出来放到最前面的方法

丢掉最久未使用的关键字的方法

相关推荐
星子落怀aa3 分钟前
Java 反复报错?Gemini助力修复
java
半夜修仙6 分钟前
RabbitMQ中如何保证消息的可靠性传输
java·分布式·中间件·rabbitmq·github·java-rabbitmq
Flittly8 分钟前
【AgentScope Java新手村系列】(3)工具系统
java·spring boot·spring
qq_85730581910 分钟前
python语法
开发语言·python·算法
吴声子夜歌10 分钟前
Java——多线程编程技巧
java·多线程
AI行业学习24 分钟前
CC-Switch v3.16.1 官方下载 | 安装配置详细教程【2026.6.10】
java·开发语言·vue.js·python·mysql·eclipse·html
周杰伦的稻香1 小时前
Go + Redis:本地部署高性能图片主色调提取服务
开发语言·redis·golang
吴梓穆1 小时前
Python 语法基础 函数
开发语言·python
不负岁月无痕1 小时前
C++ 模板核心内容与高频面试题汇总
java·开发语言·c++
Flittly1 小时前
【AgentScope Java新手村系列】(2)第一个Agent-基础对话
java·spring boot·spring·ai