Leetcode146. LRU 缓存(HOT100)

链接

代码:

cpp 复制代码
class LRUCache {
private:
    struct Node{
        int key,val;
        Node* left,*right;
        Node(int _key,int _val):key(_key),val(_val){}
    }*L,*R;

    unordered_map<int,Node*> hash;
    int n;

public:
    void remove(struct Node* p){
        p->left->right = p->right;
        p->right->left = p->left;
        //不要delete p;因为有可能我们只是更新一个Node,即:将它从list中remove,然后再insert进来,真正删掉一个节点是在超过capacity时
    }
    void insert(struct Node* p){
        p->right = L->right;
        p->left = L;
        L->right = p;
        p->right->left = p;
    }
    LRUCache(int capacity) {
        n = capacity;//capacity是一个形参,函数结束就销毁了,所以我们用一个n来记录
        L = new Node(-1,-1),R = new Node(-1,-1);//定义左右两个节点,用来管理双向链表。
        L->right = R,R->left = L;
    }
    
    int get(int key) {
        if(hash.count(key)==0)return -1;
        auto p = hash[key];//p是一个迭代器
        remove(p);
        insert(p);
        return p->val;
    }
    
    void put(int key, int value) {
        if(hash.count(key)){
            auto p = hash[key];
            p->val = value;
            remove(p);
            insert(p);
        }
        else{
            if(n==hash.size()){
                auto p = R->left;//p是一个Node
                remove(p);
                hash.erase(p->key);//erase需要参数key,我们通过Node找到其中的key
                delete p;
            }
            auto q = new Node(key,value);
            hash[key] = q;//not hash[key] = value;//hash的value是一个Node
            insert(q);//在双向链表中插入时,别忘了在hash中也插入
        }
    }
};

图解:

L和R是两个指向虚拟左右节点的指针,它们中间管理所有已经在hash表中的key value值以及相邻节点的地址。

相关推荐
芥末虾10 分钟前
【优选算法】KMP模式匹配算法 {算法介绍;算法原理:核心原理,如何求next数组;代码实现}
c语言·c++·算法·kmp·字符串模式匹配
曾几何时`15 分钟前
对撞双指针(七)三数之和
数据结构·算法·leetcode
薔薇十字16 分钟前
【代码随想录day36】【C++复健】1049. 最后一块石头的重量 II ; 494. 目标和 ;474.一和零
c++·算法·leetcode
一只小透明啊啊啊啊18 分钟前
【代码随想录】哈希
算法·哈希算法
m0_6949380118 分钟前
Leetcode打卡:最小区间
算法·leetcode·职场和发展
阿阿越25 分钟前
数据结构进阶(C++) -- AVL树的实现
数据结构·c++
使者大牙36 分钟前
【LLM学习笔记】第四篇:模型压缩方法——量化、剪枝、蒸馏、分解
人工智能·深度学习·算法·机器学习
Matlab程序猿小助手37 分钟前
【MATLAB源码-第222期】基于matlab的改进蚁群算法三维栅格地图路径规划,加入精英蚁群策略。包括起点终点,障碍物,着火点,楼梯。
开发语言·人工智能·算法·matlab·机器人·无人机
迷迭所归处41 分钟前
优先算法 —— 双指针系列 - 复写零
算法
向前看-1 小时前
青训营刷题笔记17
c++·笔记·算法