15 LRU缓存

146. LRU 缓存 - 力扣(LeetCode)

这道题采用双向链表加哈希表;

哈希表是为了随机访问,双向链表是为了能够确定位置

这里面注意的是我们需要一个哨兵节点来辅助,需要让哨兵节点的prev.next以及next.next指向自己,即这里是一个双向循环链表,并且我们每次头插节点的时候都是头插在哨兵节点之后

复制代码
class LRUCache {
    //这里put和get想实现O1那么就需要使用哈希表,但是哈希表是没有位置观念的
    //比如我们想删除最久插入的元素,那么只能一个个遍历,而有位置观念的就是数组和链表了
    //但是我们每次插入元素的时候都要放到最前面也就是头插,如果用数组的话,那么元素需要
    //整体移动,所以采用双向链表

    static class Node{
        int key;
        int val;
        Node prev;
        Node next;
        Node(int k ,int v){
            key = k;
            val = v;
        }
    }
    private int capacity;
    private Map<Integer,Node> map = new HashMap<>();
    //设置一个哨兵节点
    private Node head  = new Node(0,0);
 
 //构造初始化
    public LRUCache(int capacity) {
        this.capacity = capacity;
        head.next = head;
        head.prev = head;
    }
    
    public int get(int key) {
        //获取最新节点的值
        Node node = getNode(key);
        return node == null ? -1 : node.val;
        
    }
    
    public void put(int key, int value) {
        Node node = getNode(key);
        if(node != null){
            map.put(key,node);
            node.val = value;
            return;
        } 
        //不存在插入
        Node newNode = new Node(key,value);
        addLeft(newNode);
        map.put(key,newNode);
        if(map.size() > capacity) {
            Node last = head.prev;
            remove(last);
            map.remove(last.key);
        }
        
    }
    private Node getNode(int key){
        Node node = map.get(key);
        if(node == null) return null;
        remove(node);
        addLeft(node);
        return node;
    }
    private void remove(Node node){
        node.next.prev = node.prev;
        node.prev.next = node.next;
    }
    private void addLeft(Node node){
        //插到烧饼节点后面
        node.prev = head;
        node.next = head.next;
        head.next.prev = node;
        head.next = node;
        // node.prev.next = node;
        // node.next.prev = node;
    }
}
相关推荐
小O的算法实验室几秒前
2023年IEEE TITS SCI2区TOP,增强遗传算法+分布式随机多无人机协同区域搜索路径规划,深度解析+性能实测
算法·论文复现·智能算法·智能算法改进
Allen_LVyingbo8 分钟前
病历生成与质控编码的工程化范式研究:从模型驱动到系统治理的范式转变
前端·javascript·算法·前端框架·知识图谱·健康医疗·easyui
一起努力啊~8 分钟前
算法刷题--螺旋矩阵II+区间和+开发商购买土地
数据结构·算法·leetcode
Swift社区9 分钟前
LeetCode 470 用 Rand7() 实现 Rand10()
算法·leetcode·职场和发展
闻缺陷则喜何志丹11 分钟前
【图论 DFS 换根法】3772. 子图的最大得分|2235
c++·算法·深度优先·力扣·图论·换根法
一只大侠的侠14 分钟前
Python实现TTAO算法:优化神经网络中的时序预测任务
python·神经网络·算法
ID_180079054733 小时前
小红书笔记详情API接口基础解析:数据结构与调用方式
数据结构·数据库·笔记
千金裘换酒8 小时前
LeetCode 移动零元素 快慢指针
算法·leetcode·职场和发展
wm10439 小时前
机器学习第二讲 KNN算法
人工智能·算法·机器学习
NAGNIP9 小时前
一文搞懂机器学习线性代数基础知识!
算法