【leetcode】LRU & LFU

什么是LRU算法? LRU是Least Recently Used的缩写,即最近最少使用,常用于页面置换算法,是为虚拟页式存储管理服务的。

关于操作系统的内存管理,如何节省利用容量不大的内存为最多的进程提供资源,一直是研究的重要方向。而内存的虚拟存储管理,是现在最通用,最成功的方式--

在内存有限的情况下,扩展一部分外存作为虚拟内存,真正的内存只存储当前运行时所用得到信息。这无疑极大地扩充了内存的功能,极大地提高了计算机的并发度。虚拟页式存储管理,则是将进程所需空间划分为多个页面,内存中只存放当前所需页面,其余页面放入外存的管理方式。

然而,有利就有弊,虚拟页式存储管理增加了进程所需的内存空间,却也带来了运行时间变长这一缺点:进程运行过程中,不可避免地要把在外存中存放的一些信息和内存中已有的进行交换,由于外存的低速,这一步骤所花费的时间不可忽略。因而,采取尽量好的算法以减少读取外存的次数,也是相当有意义的事情

--from 360百科

LRU:Least Recently Used

使用代码实现,思路:

借助LinkedHashMap

复制代码
import java.util.*;
class LRUCache {
    private int capacity;
    LinkedHashMap<Integer, Integer> maps = new LinkedHashMap<>();
 
    public LRUCache(int capacity) {
       this.capacity = capacity;
    }
    
    public int get(int key) {
       if(!maps.containsKey(key)){
        return -1;
       }
       makeRecent(key);
       return maps.get(key);
    }
    
    public void put(int key, int value) {
         if(maps.containsKey(key)){
            maps.remove(key);
             maps.put(key, value);
             return;
       }

        if(maps.size() >= capacity){
           removeLast();
        }

       maps.put(key, value);
    
    }

    public void makeRecent(int key){
        int v =  maps.get(key);
        maps.remove(key);
        maps.put(key, v);
    }
    public void removeLast(){
        maps.remove(maps.keySet().iterator().next());
    }
}

/**
 * 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);
 */

扩展的,对于LFU, 根据使用频次,内存满时淘汰掉

复制代码
     Map<Integer, Node> cache;  // 存储缓存的内容, 从这里返回get
     
    Map<Integer, LinkedHashSet<Node>> freqMap; // 存储每个频次对应的双向链表,
    
    int size;
    int capacity;
    int min; // 存储当前最小频次
相关推荐
你不是我我2 小时前
【Java 开发日记】HTTP3 性能更好,为什么内网微服务依然多用 HTTP2?HTTP2 内网优势是什么?
java·开发语言·微服务
雪碧聊技术2 小时前
大模型爆火!Java后端如何抓住Agent全栈开发的风口
java·大模型·agent·全栈开发
milo.qu2 小时前
RockyLinux9.7 docker部署Jisti Meet
linux·docker·容器
GanGanGanGan_2 小时前
CentOS 7.9 glibc 2.17 源码编译升级到 glibc 2.31
linux·运维·centos·glibc
charlie1145141912 小时前
嵌入式Linux驱动开发——class 和 device 模型 - 自动创建设备节点的幕后机制
linux·运维·驱动开发
逻辑驱动的ken3 小时前
Java高频面试场景题25
java·开发语言·深度学习·面试·职场和发展
枳实-叶4 小时前
【Linux驱动开发】第四天:dmesg日志全解+驱动加载失败极速排查
linux·运维·驱动开发
AI人工智能+电脑小能手4 小时前
【大白话说Java面试题】【Java基础篇】第32题:Java的异常处理机制是什么
java·开发语言·后端·面试
wdfk_prog5 小时前
正常关闭虚拟机时,不要点“关机”,而要点“关闭客户机”
linux·c语言·网络·ide·vscode
爱吃土豆的马铃薯ㅤㅤㅤㅤㅤㅤㅤㅤㅤ5 小时前
通过java后端代码来实现给word内容补充格式文本内容控件,以及 设置控件的标记和标题
java·c#·word