Leetcode Hot100 第18题 146.LRU缓存

cpp 复制代码
struct Node{
    int key,value;
    Node *prev,*next;
    Node(): key(0),value(0),prev(nullptr),next(nullptr) {}
    Node(int _key, int _value): key(_key),value(_value),prev(nullptr),next(nullptr) {}
};
class LRUCache {
public:
    int capacity,size;
    Node *head, *tail;
    unordered_map<int,Node*> cache;
    LRUCache(int _capacity) {
        capacity = _capacity;
        size = 0;
        head = new Node();
        tail = new Node();
        head->next = tail;
        tail->prev = head;
    }
    
    int get(int key) {
        if(cache.count(key)){
            Node* node = cache[key];
            removeNode(node);
            addNodeTohead(node);
            return node->value;
        }
        return -1;
    }
    
    void put(int key, int value) {
        if(cache.count(key)){
            Node* node = cache[key];
            removeNode(node);
            addNodeTohead(node);
            node->value = value;
        }else{
            if(size==capacity){
                Node* node = tail->prev;
                removeNode(node);
                cache.erase(node->key);
                delete node;
                size--;
            }
            Node* node = new Node(key,value);
            addNodeTohead(node);
            cache[key]=node;
            size++;
        }
    }

    void removeNode(Node *node){
        node->prev->next = node->next;
        node->next->prev = node->prev;
    }

    void addNodeTohead(Node *node){
        node->next = head->next;
        node->prev = head;
        head->next->prev = node;
        head->next = node;
    }
};

/**
 * 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);
 */
相关推荐
海的诗篇_2 分钟前
移除元素-JavaScript【算法学习day.04】
javascript·学习·算法
自动驾驶小卡13 分钟前
A*算法实现原理以及实现步骤(C++)
算法
Unpredictable22215 分钟前
【VINS-Mono算法深度解析:边缘化策略、初始化与关键技术】
c++·笔记·算法·ubuntu·计算机视觉
编程绿豆侠16 分钟前
力扣HOT100之多维动态规划:1143. 最长公共子序列
算法·leetcode·动态规划
珂朵莉MM22 分钟前
2021 RoboCom 世界机器人开发者大赛-高职组(初赛)解题报告 | 珂学家
java·开发语言·人工智能·算法·职场和发展·机器人
fail_to_code1 小时前
递归法的递归函数何时需要返回值
算法
C137的本贾尼1 小时前
(每日一道算法题)二叉树剪枝
算法·机器学习·剪枝
笑口常开xpr2 小时前
数 据 结 构 进 阶:哨 兵 位 的 头 结 点 如 何 简 化 链 表 操 作
数据结构·链表·哨兵位的头节点
BUG收容所所长3 小时前
栈的奇妙世界:从冰棒到算法的华丽转身
前端·javascript·算法
XRZaaa3 小时前
常见排序算法详解与C语言实现
c语言·算法·排序算法