C++ LRU缓存

题目:
在这里插入图片描述

//构建双向链表的节点结构(要有两个构造函数)
struct Node{
    int key, val;
    Node* pre;
    Node* next;
    Node():key(0), val(0), pre(nullptr), next(nullptr) {}
    Node(int _key, int _val): key(_key), val(_val), pre(nullptr), next(nullptr) {}
};

class LRUCache {
private:
    //哈希表存放key和节点的映射
    unordered_map<int, Node*> m;
    Node* head;
    Node* tail;
    int capacity, size;
public:
    //LRU构造函数中,设定capacity和size(当前容量)、创建伪头、尾节点并相连
    LRUCache(int _capacity) : capacity(_capacity), size(0){
        head = new Node();
        tail = new Node();
        head->next = tail;
        tail->pre = head;
    }
    
    //取值:如果表里没有这个key,返回-1;如果有,更新节点值,并将其移动至头部
    int get(int key) {
        if(!m.count(key)) return -1;
        Node* node = m[key];
        remove(node);
        add(node);
        return node->val;
    }
    
    //放值:如果表里找到,更新值并移动到头部;如果没找到,执行插入操作,插入前先判断是否溢出容量,是的话移除尾部节点,还要将其从表里删除,当前容量减一,然后将新节点加入头部、表、容量加一
    void put(int key, int value) {
        if(m.count(key)){
            Node* node = m[key];
            node->val = value;
            remove(node);
            add(node);
        }else{
            Node* node = new Node(key, value);
            if(size==capacity){
                Node* del = tail->pre;
                m.erase(del->key);
                remove(del);
                size--;
            }
            add(node);
            size++;
            m[key] = node;
        }
    }
    
    //删除节点
    void remove(Node* node){
        node->pre->next = node->next;
        node->next->pre = node->pre;
    }
    
    //将节点移动至头结点
    void add(Node* node){
        node->next = head->next;
        node->pre = head;        
        head->next->pre = node;
        head->next = node;
    }

};

参考视频:LeetCode 每日一题146. LRU 缓存 | 手写图解版思路 + 代码讲解

相关推荐

  1. <span style='color:red;'>CLR</span>学习

    CLR学习

    2024-03-10 14:32:05      43 阅读
  2. 缓存

    2024-03-10 14:32:05       65 阅读
  3. 什么是CLR

    2024-03-10 14:32:05       21 阅读
  4. 缓存缓存缓存

    2024-03-10 14:32:05       32 阅读
  5. Buffer(缓冲)、Cache(缓存

    2024-03-10 14:32:05       62 阅读
  6. C#面:简述 CTS , CLS , CLR , IL

    2024-03-10 14:32:05       44 阅读
  7. 源码安装 clr - hip runtime

    2024-03-10 14:32:05       37 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-03-10 14:32:05       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-03-10 14:32:05       100 阅读
  3. 在Django里面运行非项目文件

    2024-03-10 14:32:05       82 阅读
  4. Python语言-面向对象

    2024-03-10 14:32:05       91 阅读

热门阅读

  1. WSL2-在Ubuntu-22.04上安装MySQL(deb包)并配置ODBC

    2024-03-10 14:32:05       38 阅读
  2. SQL中如何添加数据:基础指南

    2024-03-10 14:32:05       39 阅读
  3. 大恒相机SDK开发

    2024-03-10 14:32:05       36 阅读
  4. 多分类使用sklearn计算y_pred和y_prob

    2024-03-10 14:32:05       39 阅读
  5. python web开发-基于Flask+LeanCloud小店定时任务

    2024-03-10 14:32:05       43 阅读
  6. Spring 事务的种类 ? 传播机制 ?

    2024-03-10 14:32:05       38 阅读
  7. 《More Effective C++》- 极精简版 21-30条

    2024-03-10 14:32:05       40 阅读
  8. 面试怎么介绍Dubbo

    2024-03-10 14:32:05       41 阅读
  9. 生成子序列和 有序的nlog(n) 算法

    2024-03-10 14:32:05       44 阅读