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);
 */
相关推荐
西阳未落9 分钟前
欧拉路径与欧拉回路
算法·深度优先
Swift社区23 分钟前
LeetCode 390 消除游戏
算法·leetcode·游戏
橘颂TA1 小时前
【剑斩OFFER】优雅的解法——三数之和
算法
我爱工作&工作love我1 小时前
2024-CSP-J T3 小木棍
算法·动态规划
DatGuy1 小时前
Week 18: 深度学习补遗:Stacking和量子运算Deutsch算法
人工智能·深度学习·算法
Nie_Xun3 小时前
ROS1 go2 vlp16 局部避障--3 篇
算法
Da Da 泓7 小时前
LinkedList模拟实现
java·开发语言·数据结构·学习·算法
海琴烟Sunshine7 小时前
Leetcode 14. 最长公共前缀
java·服务器·leetcode
未知陨落7 小时前
LeetCode:68.寻找两个正序数组的中位数
算法·leetcode
努力学习的小廉9 小时前
我爱学算法之—— 模拟(下)
c++·算法