[力扣 Hot100]Day35 LRU 缓存

题目描述

请你设计并实现一个满足 LRU (最近最少使用) 缓存 约束的数据结构。

实现 LRUCache 类:

LRUCache(int capacity) 以 正整数 作为容量 capacity 初始化 LRU 缓存

int get(int key) 如果关键字 key 存在于缓存中,则返回关键字的值,否则返回 -1 。

void put(int key, int value) 如果关键字 key 已经存在,则变更其数据值 value ;如果不存在,则向缓存中插入该组 key-value 。如果插入操作导致关键字数量超过 capacity ,则应该 逐出 最久未使用的关键字。

函数 get 和 put 必须以 O(1) 的平均时间复杂度运行。

出处

思路

写了两个版本都超时,单向链表和迭代器的查找都太慢,需要用哈希表。

代码

cpp 复制代码
class LRUCache {
private:
    int len;
    list<pair<int, int>> lru;
    unordered_map<int, list<pair<int, int>>::iterator> map;
public:
    LRUCache(int capacity) {
        len=capacity;
    }
    
    int get(int key) {
        if (map.find(key) == map.end()) return -1;
        pair<int,int> key_value = *map[key];
        lru.erase(map[key]);
        lru.push_front(key_value);
        map[key] = lru.begin();
        return key_value.second;
    }
    
    void put(int key, int value) {
        if (map.find(key) == map.end()) {
            if (lru.size() == len) {
                map.erase(lru.back().first);
                lru.pop_back();
            }
        }
        else {
            lru.erase(map[key]);
        }
        lru.push_front({key, value});
        map[key] = lru.begin();
    }
};
相关推荐
2301_8234380233 分钟前
解析论文《复杂海上救援环境中无人机群的双阶段协作路径规划与任务分配》
人工智能·算法·无人机
embrace991 小时前
【C语言学习】结构体详解
android·c语言·开发语言·数据结构·学习·算法·青少年编程
Ayanami_Reii1 小时前
基础数学算法-开关问题
数学·算法·高斯消元
稚辉君.MCA_P8_Java1 小时前
通义 Go 语言实现的插入排序(Insertion Sort)
数据结构·后端·算法·架构·golang
稚辉君.MCA_P8_Java2 小时前
Gemini永久会员 Go 实现动态规划
数据结构·后端·算法·golang·动态规划
快手技术2 小时前
快手 & 南大发布代码智能“指南针”,重新定义 AI 编程能力评估体系
算法
Murphy_lx3 小时前
C++ std_stringstream
开发语言·c++·算法
CoovallyAIHub3 小时前
超越YOLOv8/v11!自研RKM-YOLO为输电线路巡检精度、速度双提升
深度学习·算法·计算机视觉
哭泣方源炼蛊3 小时前
HAUE 新生周赛(七)题解
数据结构·c++·算法
斯文~3 小时前
「玩透ESA」站点配置阿里云ESA全站加速+自定义规则缓存
阿里云·缓存·云计算·cdn·esa