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

算法笔记:力扣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);
          
        }

    }


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

相关文章:

  • ubuntu无线网络共享到有线
  • 在 Windows Server 2022 Datacenter 上配置 MySQL 8.0 的主从复制
  • vscode切换anaconda虚拟环境解释器不成功
  • 无人机的计算机仿真模拟控制
  • 【测试工具JMeter篇】JMeter性能测试入门级教程(六):JMeter中实现参数化的几种方式
  • 利用Python爬虫获取淘宝关键词接口的深入解析
  • LeetCode78:子集
  • unity与android拓展
  • 量化交易系统开发-实时行情自动化交易-8.8.同花顺 SuperMind 平台
  • 【Oracle11g SQL详解】子查询的分类与嵌套查询实例
  • Typora设置自动上传图片到图床
  • Linux查看系统基本信息
  • 推荐文章:FLUI Framework——打造流畅的微软界面体验
  • Mysql外键约束与关联表操作
  • 讯方智汇云校HarmonyOS培训,培养鸿蒙原生应用开发人才
  • TypeScript (一)运行环境配置,数据类型,可选类型,联合类型,type与interface,交叉类型,断言as,字面量类型,类型缩小
  • 【青牛科技】超低功耗混合信号处理器由多种设备组成的流量计电路芯片——D8331
  • Linux之信号集基础
  • 怎么自己创建一个网站? 开发语言首选 java,使用CMS网站内容管理系统是不错的选择
  • Redis设计与实现第17章 -- 集群 总结2(执行命令 重新分片)