[力扣 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();
    }
};
相关推荐
Theodore_102216 分钟前
深度学习(10)模型评估、训练与选择
人工智能·深度学习·算法·机器学习·计算机视觉
五条凪21 分钟前
Verilog-Eval-v1基准测试集搭建指南
开发语言·人工智能·算法·语言模型
是店小二呀33 分钟前
从“算法思维”到“算子思维”:我在昇腾AI开发中的认知跃迁
人工智能·算法
仰泳的熊猫38 分钟前
LeetCode:72. 超级次方
数据结构·c++·算法·leetcode
塔能物联运维1 小时前
物联网边缘节点数据缓存优化与一致性保障技术
java·后端·物联网·spring·缓存
闻缺陷则喜何志丹1 小时前
【超音速专利 CN118134841A】一种光伏产品缺陷检测AI深度学习算法
人工智能·深度学习·算法·专利·光伏·超音速
爱看科技1 小时前
微美全息(NASDAQ:WIMI)容错量子计算赋能,大规模机器学习模型高效量子算法获突破
算法·机器学习·量子计算
_dindong2 小时前
牛客101:递归/回溯
数据结构·c++·笔记·学习·算法·leetcode·深度优先
Maỿbe2 小时前
Redis的持久化
数据库·redis·缓存
刃神太酷啦2 小时前
力扣校招算法通关:双指针技巧全场景拆解 —— 从数组操作到环检测的高效解题范式
java·c语言·数据结构·c++·算法·leetcode·职场和发展