您当前的位置: 首页 >  缓存

对方正在debug

暂无认证

  • 4浏览

    0关注

    399博文

    0收益

  • 0浏览

    0点赞

    0打赏

    0留言

私信
关注
热门博文

LRU缓存机制(哈希链表)

对方正在debug 发布时间:2020-03-03 16:22:59 ,浏览量:4

题目:https://leetcode-cn.com/problems/lru-cache/ 参考:https://leetcode-cn.com/problems/lru-cache/solution/lru-ce-lue-xiang-jie-he-shi-xian-by-labuladong/ 运用你所掌握的数据结构,设计和实现一个 LRU (最近最少使用) 缓存机制。它应该支持以下操作: 获取数据 get 和 写入数据 put 。

获取数据 get(key) - 如果密钥 (key) 存在于缓存中,则获取密钥的值(总是正数),否则返回 -1。 写入数据 put(key, value) - 如果密钥不存在,则写入其数据值。当缓存容量达到上限时,它应该在写入新数据之前删除最近最少使用的数据值,从而为新的数据值留出空间。 题解:unordered_map+双向链表,get和put操作实现O(1)。

class LRUCache {
public:
    int cap;
    list li;
    unordered_map mp;
    
    LRUCache(int capacity) {
        cap = capacity;
        li.clear();
        mp.clear();
    }
    
    int get(int key) {
        auto it = mp.find(key);
        if(it == mp.end()) return -1;
        pair p = *mp[key];
        li.erase(mp[key]);//删除数据
        li.push_front(p);//更新链表
        mp[key] = li.begin();//更新map
        return p.second;
    }
    
    void put(int key, int value) {
        auto it = mp.find(key);
        if(it == mp.end()) {//原key不存在
            if(li.size() == cap) {//满容器删back()
                mp.erase(mp.find(li.back().first));
                li.pop_back();
            }
            //加入数据,更新list/map
            li.push_front(make_pair(key,value));
            mp[key] = li.begin();
        }else {//key存在
            pair p = *mp[key];
            p.second = value;
            li.erase(mp[key]);//删除数据
            li.push_front(p);//更新链表
            mp[key] = li.begin();//更新map
        }
    }
};


/**
 * 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);
 */
关注
打赏
1664895754
查看更多评论
立即登录/注册

微信扫码登录

0.0554s