力扣:146.LRU 缓存

  1. LRU Least Recently Used
  2. cache 对速度要求严苛,是常数时间
  3. put 的要求是找到了就更新值,没找到就插入值
  4. cache 里面的 key 和 Node* 里面的 key 是同一个 key
cpp 复制代码
class LRUCache {
public:
    LRUCache(int capacity) {
        this->capacity = capacity;
        this->size = 0;
        head = new Node( 0, 0 );
        tail = new Node( 0, 0 );
        head->next = tail;
        tail->prev = head;
    }
    
    int get(int key) {
        if ( cache.find( key ) == cache.end() ) return -1;
        Node *node = cache[key];
        moveToHead( node );
        return node->val;
    }
    
    void put(int key, int value) {
        if ( cache.find( key ) != cache.end() ) {
            Node *node = cache[key];
            node->val = value;
            moveToHead( node );
        } else {
            Node *newNode = new Node( key, value );
            cache[key] = newNode;
            addToHead( newNode );
            size++;
            if ( size > capacity ) {
                Node *tailNode = removeTail();
                cache.erase( tailNode->key );
                delete tailNode;
                size--;
            }
        }
    }
private:
    struct Node {
        int key, val;
        Node *prev, *next;
        Node( int k, int v ) : key(k), val(v), prev(nullptr), next(nullptr) {}
    };
    int capacity;
    int size;
    Node *head, *tail;
    unordered_map<int, Node*> cache;
    void removeNode( Node *node ) {
        node->prev->next = node->next;
        node->next->prev = node->prev;
    }
    void addToHead( Node *node ) {
        node->next = head->next;
        node->prev = head;
        head->next->prev = node;
        head->next = node;
    }
    void moveToHead( Node *node ) {
        removeNode( node );
        addToHead( node );
    }
    Node *removeTail() {
        Node *res = tail->prev;
        removeNode( res );
        return res;
    }
};
相关推荐
_深海凉_1 小时前
LeetCode热题100-杨辉三角
算法·leetcode·职场和发展
小O的算法实验室1 小时前
2025年SEVC,面向进化计算的学习注入式优化,深度解析+性能实测
算法·论文复现·智能算法·智能算法改进
啊我不会诶1 小时前
2024北京市赛补题
c++·算法
shehuiyuelaiyuehao1 小时前
算法13,滑动窗口,水果成篮
算法·哈希算法·散列表
智慧物业老杨1 小时前
物业数智化转型实战:从单一服务到综合解决方案的技术落地路径
人工智能·算法·ai
夏末蝉未鸣011 小时前
Sort-Merge Join【排序连接算法】详解(python代码实现,以FULL JOIN为例)
数据结构·算法
tjl521314_212 小时前
01C++ 分离编译与多文件编程
前端·c++·算法
空中海2 小时前
第四篇:进阶篇 — 缓存、消息队列、安全与常用中间件
安全·缓存·中间件
_日拱一卒2 小时前
LeetCode:23合并K个升序链表
java·数据结构·算法·leetcode·链表·职场和发展