算法笔记:力扣146.LRU缓存

本题关键思路:当访问一个key后,就移动该key到最前面的位置或者最后面的位置,那么另一端最后一个元素就是最近最久没有访问的元素。而LinkedHashMap就是可以按照访问顺序来移动元素。

复制代码
class LRUCache {

    int cap=0;
   // HashMap<Integer,Integer> map=new HashMap<>();
    LinkedHashMap<Integer,Integer> map=null;
    //LinkedHashMap:有顺序的map 相当于hashmap+双向链表 三个参数cap 负载因子 是否按顺序排列
    //当调用一次get访问元素后 那么该元素就会放到最后

    public LRUCache(int capacity) {
        //这一步是初始化容量  表示最多存几个元素 也就是几个key
        //思路 通过一个hashmap来存放key
        this.cap=capacity;
        map=new LinkedHashMap<>(cap,0.75f,true); //对map进行初始化
    }
    
    public int get(int key) {
    return    map.getOrDefault(key,-1); //如果找到key 则返回对应的值 如果没找到则返回-1

    }
    
    public void put(int key, int value) {
        //put key和对应的value值
        //1.put元素首先要检查是否已经容量满了
        if(map.containsKey(key)){ //表示重复元素直接覆盖
            map.put(key,value);
            return;
        }
        
        if(map.size()>=cap){//表示已经满了
            //就要踢出使用得最少的 
            //LinkedHashMap的规则就是 当使用get方法后 会将get的key放到最后面 那么最前面的就是访问最少的
            for(Map.Entry<Integer,Integer> entry:map.entrySet()){
                int minkey=entry.getKey();//第一个key就是最近访问最少的
                //这里要注意put的元素是不是重复的 如果是重复元素则不需要删除
                map.remove(minkey);
                break;
            }

        }
            //然后添加元素
            map.put(key,value);
          
        }

    }
相关推荐
8Qi83 小时前
回文子串(Palindromic Substrings)—— 题解
算法·leetcode·职场和发展·动态规划
xuhaoyu_cpp_java5 小时前
项目学习(三)分页查询
java·经验分享·笔记·学习
闪电悠米7 小时前
黑马点评-Redis 消息队列-03_stream_consumer_group
开发语言·数据库·redis·分布式·缓存·junit·lua
小欣加油8 小时前
leetcode1926 迷宫中离入口最近的出口
数据结构·c++·算法·leetcode·职场和发展
qqxhb8 小时前
47|成本与性能:缓存、批处理、模型路由与降级
缓存·批处理·智能模型路由·多级降级预案·成本预算
Cloud_Shy6188 小时前
解读《Effective Python 3rd Edition》:从练气到老魔(第五章 Item 33 - 35)
开发语言·人工智能·笔记·python·学习方法
做cv的小昊9 小时前
计算机图形学:【Games101】学习笔记08——光线追踪(辐射度量学、渲染方程与全局光照、蒙特卡洛积分与路径追踪)
图像处理·笔记·学习·计算机视觉·游戏引擎·图形渲染·概率论
星恒随风9 小时前
C++ 类和对象入门(五):初始化列表、explicit 和 static 成员详解
开发语言·c++·笔记·学习·状态模式
伊布拉西莫13 小时前
【流畅的Python】第20章:并发执行器 — 学习笔记
笔记·python·学习
叶小鸡13 小时前
Java 篇-项目实战-AI 天机学堂(从 0 到 1)-day5
数据库·redis·缓存