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

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

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

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

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

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

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

相关推荐
二哈赛车手13 小时前
新人笔记---ApiFox的一些常见使用出错
java·笔记·spring
为何创造硅基生物14 小时前
C语言 结构体内存对齐规则(通俗易懂版)
c语言·开发语言
吃好睡好便好14 小时前
在Matlab中绘制横直方图
开发语言·学习·算法·matlab
栗子~~14 小时前
JAVA - 二层缓存设计(本地缓冲+redis缓冲+广播所有本地缓冲失效) demo
java·redis·缓存
星寂樱易李14 小时前
iperf3 + Python-- 网络带宽、网速、网络稳定性
开发语言·网络·python
YDS82914 小时前
DeepSeek RAG&MCP + Agent智能体项目 —— RAG知识库的搭建和接口实现
java·ai·springboot·agent·rag·deepseek
仰泳之鹅14 小时前
【C语言】自定义数据类型2——联合体与枚举
c语言·开发语言·算法
之歆14 小时前
DAY_12JavaScript DOM 完全指南(二):实战与性能篇
开发语言·前端·javascript·ecmascript
未若君雅裁15 小时前
MyBatis 一级缓存、二级缓存与清理机制
java·缓存·mybatis
cen__y16 小时前
Linux12(Git01)
linux·运维·服务器·c语言·开发语言·git