题解 | #设计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
};

全部评论

相关推荐

在笔试的大西瓜很矫健:校招数分不用想了,这经历和学历都不够用,大厂更别想,初筛都过不了,说点不好听的小厂数分都进不去(小厂也是假数分),要两个对口实习+3个项目(或者3+2),而且要有含金量才能补一点你的学历劣势。 建议刷实习,社招找数分,校招看运气,能入行业就行,可以运营转数分
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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