当前位置: 首页 > article >正文

leetcode 146. LRU 缓存

2023.10.26

         本题核心就是要将map中,最近最少操作的那个key给剔除掉,于是我们可以使用双端链表LinkedList 来维护每个元素的操作情况,最近操作的元素就将其移至表头,越久没操作的元素,自然就会沉到表尾。  一旦缓存满了,将表尾元素剔除即可。  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);
 */


http://www.kler.cn/a/105769.html

相关文章:

  • (react+ts)vite项目中的路径别名的配置
  • 共享WiFi贴推广项目怎么操作?
  • el-select multiple表单校验问题
  • 「译文」深入了解Kubernetes和Nomad
  • 【嵌入式】HC32F07X ADC采样及软件滤波
  • Uniapp中嵌入H5( uniapp开发的H5),并且在H5中跳转到APP的指定页面
  • 【Docker】Docker的应用包含Sandbox、PaaS、Open Solution以及IT运维概念的详细讲解
  • 外网访问|SD-WAN跨境网络专线助力企业摆脱网络困境
  • UnrealSynth - 基于虚幻引擎的YOLO合成数据生成器
  • Redis快速上手篇五(持久化)
  • GZ035 5G组网与运维赛题第1套
  • SpringMvc接收参数
  • 31 select max/min/avg/sum/count/group_concat 的实现
  • Response Header中不暴露Server(IIS)版本、ASP.NET及相关版本等信息
  • 第六章(5):Python中的嵌套函数
  • 目标检测的方法
  • 基于Laravel封装一个强大的请求响应日志记录中间件
  • Ubuntu 20.04 上安装和使用 Docker
  • STM32 PWM配置及呼吸灯
  • 【html】图片多矩形框裁剪