力扣: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;
    }
};
相关推荐
小白|2 分钟前
cmake:昇腾CANN构建系统完全指南
java·c++·算法
nebula-AI2 分钟前
人工智能导论:模型与算法(未来发展与趋势)
人工智能·神经网络·算法·机器学习·量子计算·automl·类脑计算
炽烈小老头4 分钟前
【每天学习一点算法 2026/05/21】课程表
学习·算法
luoganttcc8 分钟前
大模型是否即将到达算法极限
算法
1892280486134 分钟前
NY379固态MT29F32T08GSLBHL8-36QA:B
大数据·服务器·人工智能·科技·缓存
叶小鸡35 分钟前
小鸡玩算法-力扣HOT100-动态规划(上)
算法·leetcode·动态规划
LuminousCPP42 分钟前
数据结构 - 线性表第三篇:基于顺序表实现 C 语言通讯录(基础功能篇)
c语言·数据结构·经验分享·笔记·算法
_日拱一卒1 小时前
LeetCode:114二叉树展开为链表
java·开发语言·算法
牧羊狼的狼1 小时前
高并发会带来哪些问题,如何解决?
缓存·高并发
无小道1 小时前
Redis——哈希类型相关指令
redis·算法·哈希算法