题解 | #设计LRU缓存结构 使用map方法#

设计LRU缓存结构

http://www.nowcoder.com/practice/e3769a5f49894d49b871c09cadd13a61

function LRU( operators ,  k ) {
    
    var map = new Map();   //原型对象
    var list = [];
    var res = [];
    for(var item in operators){
        var op = operators[item][0];
        if(op===1){
            map.set(operators[item][1],operators[item][2]);  //set方法 map.set(key,value) 且有重复key时会重新赋值
            if(list.length>=k){
                list.shift();      //删除最前面一个(最不常用)
            }
            list.push(operators[item][1]);   //将最新的key插入到最后
        }else if(op===2){
            var key = operators[item][1];
            var index = list.indexOf(key)
            if(index==-1){
                res.push(-1);
            }else{
                res.push(map.get(key));  //获取key属性的值
                list.splice(index,1);
                list.push(key);  //删除数组中间的值并插入到最后
            }
        }
    }
    return res
}
module.exports = {
    LRU : LRU
};

全部评论

相关推荐

2025-11-13 14:37
门头沟学院 Java
程序员牛肉:是的,我觉得你最先需要的是多接触计算机圈子。我感觉你这个写的太幼稚了,根本没换位思考面试官。 你对实习的描述还是我写了前后端,我写了Restful接口,我用了EChatrs。你这让面试官怎么问你?问你什么是前后端?问你什么是Restful?讲真的兄弟,你这个简历在面试官眼里就是啥也不懂的好学生。所以一定要尽快加入一个圈子跟大家多聊聊,看看正儿八经的简历是怎么写的。 可以看一下我首页的简历怎么写那篇文章来学一下,你这里面的坑点我那篇文章里面都有讲过。
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务