博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
牛客网 | 高频面试题 | 设计LRU缓存结构
阅读量:4141 次
发布时间:2019-05-25

本文共 1419 字,大约阅读时间需要 4 分钟。

文章目录

题目

示例1	输入		[[1,1,1],[1,2,2],[1,3,2],[2,1],[1,4,4],[2,2]],3	返回值		[1,-1]说明	第一次操作后:最常使用的记录为("1", 1)	第二次操作后:最常使用的记录为("2", 2),("1", 1)变为最不常用的	第三次操作后:最常使用的记录为("3", 2),("1", 1)还是最不常用的	第四次操作后:最常用的记录为("1", 1),("2", 2)变为最不常用的	第五次操作后:大小超过了3,所以移除此时最不常使用的记录("2", 2),加入记录("4", 4),并且为最常使用的记录,然后("3", 2)变为最不常使用的记录

解析

class Solution {
private:public: /** * lru design * @param operators int整型vector
<>> the ops,操作数 * @param k int整型 the k ,LRU缓存大小为k * @return int整型vector */ int capacity; list
> lrulst;//链表 //list
>::iterator 指向里面的元素 unordered_map
>::iterator > lruhash;//map vector
LRU(vector
>& operators, int k) { // write code here vector
res; capacity = k; for(auto opt : operators){ switch (opt[0]){ case 1: set(opt[1],opt[2]); break; case 2: res.push_back(get(opt[1])); break; default: break; } } return res; } void set(int key,int val){ auto iter = lruhash.find(key); //判断是否存在 if(iter == lruhash.end()) { //如果容积满了 if(capacity == lrulst.size()) { //删掉最末元素 lruhash.erase(lrulst.back().first); lrulst.pop_back(); } } else lrulst.erase(iter->second);//删掉更新一下 //更新 lrulst.push_front({ key,val}); lruhash[key] = lrulst.begin(); } int get(int key){ auto iter = lruhash.find(key); if(iter == lruhash.end()) return -1; int val = iter->second->second; //删掉链表节点,再重新添加 lrulst.erase(iter->second); lrulst.push_front(*iter->second); return val; }};

转载地址:http://qzevi.baihongyu.com/

你可能感兴趣的文章
前阿里手淘前端负责人@winter:前端人如何保持竞争力?
查看>>
【JavaScript 教程】面向对象编程——实例对象与 new 命令
查看>>
我在网易做了6年前端,想给求职者4条建议
查看>>
SQL1015N The database is in an inconsistent state. SQLSTATE=55025
查看>>
RQP-DEF-0177
查看>>
MySQL字段类型的选择与MySQL的查询效率
查看>>
Java的Properties配置文件用法【续】
查看>>
JAVA操作properties文件的代码实例
查看>>
IPS开发手记【一】
查看>>
Java通用字符处理类
查看>>
文件上传时生成“日期+随机数”式文件名前缀的Java代码
查看>>
Java代码检查工具Checkstyle常见输出结果
查看>>
北京十大情人分手圣地
查看>>
Android自动关机代码
查看>>
Android中启动其他Activity并返回结果
查看>>
2009年33所高校被暂停或被限制招生
查看>>
GlassFish 部署及应用入门
查看>>
iWatch报错: Authorization request cancled
查看>>
iWatch报错: Authorizationsession time out
查看>>
X-code7 beta error: warning: Is a directory
查看>>