【LeetCode热题100(35/100)】LRU 缓存

题目地址: 链接
思路: 利用 this.map.keys() 按照顺序存储特性并且 O(1) 时间复杂度完成存取,可以很好完成题目,并且 get 和 put 时间复杂度都为 O(1)

当前js 代码不能通过所有案例,有大佬能解释一下吗?

js 复制代码
/**
 * @param {number} capacity
 */
var LRUCache = function(capacity) {
    this.capacity = capacity;
    this.map = new Map();
};

/** 
 * @param {number} key
 * @return {number}
 */
LRUCache.prototype.get = function(key) {
    let ans = -1;
    if(this.map.has(key)) {
        ans = this.map.get(key);
        this.map.delete(key);
        this.map.set(key, ans);
    }
    return ans;
};

/** 
 * @param {number} key 
 * @param {number} value
 * @return {void}
 */
LRUCache.prototype.put = function(key, value) {
    if(this.map.has(key)) {
        this.map.delete(key);
    }

    if(this.map.size >= this.capacity) {
        let oldkey = this.map.keys().next().value;
        this.map.delete(oldkey);
    }
    this.map.set(key, value);
};

/** 
 * Your LRUCache object will be instantiated and called as such:
 * var obj = new LRUCache(capacity)
 * var param_1 = obj.get(key)
 * obj.put(key,value)
 */
相关推荐
008爬虫实战录7 小时前
【码上爬】 题十:魔改算法 堆栈分析,找加密值过程详解
前端·python·算法
chao1898447 小时前
基于狮蚁群算法(ALO)的火电机组功能调度实现
人工智能·算法
Deep-w7 小时前
【MATLAB】含光伏 - 储能的家庭/工业微电网能量管理仿真研究
开发语言·算法·matlab
阿文的代码库7 小时前
换根技巧实例分析:最小高度树
算法·动态规划
Trouvaille ~7 小时前
【Redis篇】初识 Redis:特性、应用场景与版本演进
数据结构·数据库·redis·分布式·缓存·中间件·持久化
dyxal7 小时前
Louvain 算法:让网络自己“报团取暖”的发现者
开发语言·算法
计算机安禾7 小时前
【c++面向对象编程】第41篇:函数模板与类模板:泛型编程的基石
开发语言·c++·算法
SilentSamsara8 小时前
属性查找顺序:实例 → 类 → 父类的完整 MRO
开发语言·python·算法·青少年编程
不知名的老吴8 小时前
浅谈:树形动态规划中的换根技巧
算法·动态规划
一条大祥脚8 小时前
2021-2022 ICPC Southwestern Europe Regional Contest
算法·深度优先·图论