当前位置: 首页 > news >正文

网络服务营业部seo网站优化培训怎么样

网络服务营业部,seo网站优化培训怎么样,杭州网站制作公司排名,wordpress做管理网站题目内容 实现一个 LRUCache 类,三个接口: LRUCache(int capacity) 创建一个大小为 capacity 的缓存get(int key) 从缓存中获取键为 key 的键值对的 valueput(int key, int value) 向缓存中添加键值对 (key, value) 要求 get 和 put 的均摊时间复杂度…

题目内容

实现一个 LRUCache 类,三个接口:

  • LRUCache(int capacity) 创建一个大小为 capacity 的缓存
  • get(int key) 从缓存中获取键为 key 的键值对的 value
  • put(int key, int value) 向缓存中添加键值对 (key, value)

要求 getput 的均摊时间复杂度为 O ( 1 ) O(1) O(1)

题解

对于 get 操作,我们需要快速获取到 key 对应的键值对,哈希表可以解决。
对于 put 操作,我们需要快速 put 一个键值对,也可以用哈希表解决。

但是问题在于,我们 getput 时,需要维护键值对最近使用的情况。

这部分我们可以用双向链表维护,每次操作一个键值对时,将其从原来链表的位置中移除,重新添加到链表头。定义链表头的数据是最近一次使用的,链表尾是最近最少使用的。

对于哈希表,键可以为 key ,映射到一个链表结点 LRUNodeLRUNode 中包括前后链表结点,以及当前链表结点的 keyvalue

为什么我们要在链表结点中存储 key 呢,直接看上去没什么用。
考虑我们需要利用 LRU 策略从缓存中弹出一个最近最少使用的结点。
根据我们的定义,链表尾的结点是最近最少使用的,除了要将其从链表中移除,还需要将其从哈希表中移除,而从哈希表中移除需要使用 key ,这才是链表结点中存储 key 的原因。

定义LRU中的链表结点 LRUNode

struct LRUNode {LRUNode* prev;LRUNode* next;int key;int val;LRUNode(int key, int val): key(key), val(val), prev(nullptr), next(nullptr) {}
};

对于 LRUNode ,其会从链表中被移除,也会被添加到链表,所以需要实现这两个方法

void removeLRUNodeFromLinklist(LRUNode* node) {node->prev->next = node->next;node->next->prev = node->prev;
}void insertLRUNodeToLinklist(LRUNode* node) {node->next = head->next;head->next->prev = node;head->next = node;node->prev = head;
}

对于 LRUNode ,其会从哈希表 key2LRUNode 中被移除,也会被添加到哈希表 key2LRUNode,所以需要实现这两个方法

void removeLRUNodeFromHashTable(LRUNode* node) {if (!key2LRUNode.count(node->key)) return;key2LRUNode.erase(node->key);
}void insertLRUNodeToHashTable(LRUNode* node) {key2LRUNode[node->key] = node;
}

接下来实现 get 的逻辑

int get(int key) {// key 不存在if (!key2LRUNode.count(key)) return -1;// 取出 key 对应的 LRUNodeLRUNode* node = key2LRUNode[key];// 当前 LRUNode 是最近一次使用的,将其放到链表头removeLRUNodeFromLinklist(node);insertLRUNodeToLinklist(node);return node->val;
}

继续实现 put 的逻辑

void put(int key, int value) {// 如果不存在 key ,则需要新建该键值对if (!key2LRUNode.count(key)) {// 缓存已满,要从缓存中通过LRU策略弹出最近最少使用的LRUNodeif (size_ >= capacity_) {// 链表尾即最近最少使用的LRUNode* node = tail->prev;// 从链表中删去removeLRUNodeFromLinklist(node);// 从哈希表中删去removeLRUNodeFromHashTable(node);// 释放 node 的内存空间,如果是智能指针就不需要手动释放了delete node;// 释放一个空间size_ -= 1;}// 创建一个新的 LRUNodeLRUNode* newLRUNode = new LRUNode(key, value);// 添加到链表中insertLRUNodeToLinklist(newLRUNode);// 添加到哈希表中insertLRUNodeToHashTable(newLRUNode);size_ += 1;} else {// 获取到 key 对应的已存在于缓存中的 LRUNode 节点LRUNode* node = key2LRUNode[key];// 更新键值对的权值node->val = value;// 从链表中删去removeLRUNodeFromLinklist(node);// 添加到链表中insertLRUNodeToLinklist(node);// 添加到哈希表中,其实这步是不需要的,因为哈希表对应的是 LRUNode 的地址insertLRUNodeToHashTable(node);// 这里只是 key 对应的 value 修改了,size_ 不变}
}
http://www.khdw.cn/news/12050.html

相关文章:

  • 绝对域名做网站重庆白云seo整站优化
  • 专业做排行的网站杭州seo中心
  • 网页设计教程视频教程大型seo公司
  • 网站如何导入织梦cms百度助手手机下载
  • 专业建站公司提供详细的功能描述及报价百度的关键词优化
  • 做外贸的有哪些网站有哪些下载百度2024最新版
  • vue 实现网站开发痘痘该如何去除效果好
  • 广元网站建设seo优化营销制作设计网址之家
  • 做网站客户要提供什么网站功能
  • 如果自己想建设网站该怎么做网站建设详细方案模板
  • 柳州网站建设灰色词排名代做
  • 做外贸商城网站网站托管维护
  • 网络推广具体方式有哪些国际站seo优化是什么意思
  • 网站缩放代码seo做得比较好的企业案例
  • 旅游网站设计风格重庆seo公司排名
  • 四川省建设三类职称网站北京学校线上教学
  • 高校两学一做网站建设惠州seo博客
  • 如何做网站关键词霸屏河南做网站优化
  • 邯郸网站建设多少钱日本搜索引擎naver入口
  • ecshop网站模版seo整站优化解决方案
  • 做任务赚钱的正规网站微信群推广
  • 域名查询中心官网网站优化分析
  • 做淘宝还是做网站百度推广电话号码
  • 做网站app公司前景北京网站优化对策
  • 网站架构制作有实力的网站排名优化软件
  • 济南市建设局网站查房产信息一份完整的营销策划书
  • 网站设计是什么专业seo搜索优化排名
  • 网站建设尺寸惠州网络推广平台
  • 网站实施过程网络营销个人总结
  • 网站建设遇到哪些问题今天新疆新闻头条