leetcode 146. LRU 缓存

2023.10.26

本题核心就是要将map中,最近最少操作的那个key给剔除掉,于是我们可以使用双端链表LinkedList 来维护每个元素的操作情况,最近操作的元素就将其移至表头,越久没操作的元素,自然就会沉到表尾。 一旦缓存满了,将表尾元素剔除即可。 java代码如下:

java 复制代码
class LRUCache {
    private int capacity;
    Map<Integer,Integer> map = new HashMap<>();
    LinkedList<Integer> LRUlist = new LinkedList<>();

    public LRUCache(int capacity) {
        this.capacity = capacity;
    }
    
    public int get(int key) {
        if(map.containsKey(key)){
            LRUlist.remove((Integer)key);
            LRUlist.addFirst(key);
            return map.get(key);
        } 
        else return -1;
    }
    
    public void put(int key, int value) {
        //找到该元素
        if(map.containsKey(key)){
            LRUlist.remove((Integer)key);
            LRUlist.addFirst(key);
            map.put(key,value); 
        }
        //未找到该元素
        else{
            //map内元素未超出容量,直接put
            if(map.size() < capacity){
                map.put(key,value);
                LRUlist.addFirst(key);
            }
            //map内元素超出容量capacity,先删掉最近最少未使用的元素,再put
            else{
                int temp = LRUlist.removeLast();
                map.remove(temp);
                map.put(key,value);
                LRUlist.addFirst(key);
            }
        }
    }
}

/**
 * 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);
 */
相关推荐
努力也学不会java7 分钟前
【设计模式】抽象工厂模式
java·设计模式·oracle·抽象工厂模式
小刘鸭地下城8 分钟前
深入浅出链表:从基础概念到核心操作全面解析
算法
用户60830892904717 分钟前
集合处理利器,Java中的Stream流API
java·后端
玉衡子18 分钟前
八、MySQL全局优化总结&MySQL8新特性
java·mysql
小刘鸭地下城18 分钟前
哈希表核心精要:从 O(1) 原理到链式地址与开放寻址
算法
9号达人20 分钟前
Java 14 新特性详解与实践
java·后端·面试
ytadpole23 分钟前
揭秘XXL-JOB:Bean、GLUE 与脚本模式的底层奥秘
java·后端
今后12336 分钟前
【数据结构】二叉树的概念
数据结构·二叉树
计算机毕业设计木哥38 分钟前
计算机毕设选题推荐:基于Java+SpringBoot物品租赁管理系统【源码+文档+调试】
java·vue.js·spring boot·mysql·spark·毕业设计·课程设计
青衫客3638 分钟前
Spring异步编程- 浅谈 Reactor 核心操作符
java·spring·响应式编程