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

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

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

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

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

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

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

相关推荐
StockTV1 小时前
韩国股票实时数据 KOSPI(主板)和 KOSDAQ(创业板)的实时行情、K 线及指数数据
java·开发语言·算法·php
Java成神之路-1 小时前
面试题:SpringMVC执行流程(视图版+前后端分离版)
java·springmvc
豆瓣鸡1 小时前
Agent实战练习
java·python·学习
Brilliantwxx1 小时前
【C++】认识标准库STL(2)
开发语言·c++
故事还在继续吗2 小时前
STL 容器算法手册
开发语言·c++·算法
weisian1512 小时前
Java并发编程--48-美团Leaf与百度UidGenerator:分布式ID生成器的工业级实践
java·leaf号段模式·leaf雪花模式·uidgenerator
郝开2 小时前
Spring Cloud Gateway 3.5.14 使用手册
java·数据库·spring boot·gateway