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

天津平台网站建设企业seocui cn

天津平台网站建设企业,seocui cn,网站备案初审,扬中网站建设方案文章目录 LRU实现 LRU 优先去除最久没有访问到的数据。 实现 通过组合哈希表(Hash Table)和双向链表(Doubly Linked List)实现 LRU 缓存。并且以 O(1) 的时间复杂度执行 get 和 put 操作核心是对节点的新增、访问都会让节点移动…

文章目录

  • LRU
  • 实现

LRU

  • 优先去除最久没有访问到的数据。

实现

  • 通过组合哈希表(Hash Table)和双向链表(Doubly Linked List)实现 LRU 缓存。并且以 O(1) 的时间复杂度执行 get 和 put 操作
  • 核心是对节点的新增、访问都会让节点移动到双向链表头部,当容量超过时,直接删除尾部节点即可
class LRUCache {constructor(capacity) {// 容量this.capacity = capacity;this.cache = new Map();// 用于记录访问顺序的双向链表,声明空的头节点和尾节点this.head = {};this.tail = {};// 头和尾相连this.head.next = this.tail;this.tail.prev = this.head;}get(key) {const map = this.cache;if (!map.has(key)) {return -1;}// 每次把使用的节点放到链表的头部const node = map.get(key);this._moveToHead(node);return node.value;}put(key, value) {const map = this.cache;// 如果 key 已存在,更新并移动到双向链表头部if (map.has(key)) {const node = map.get(key);node.value = value;this._moveToHead(node);} else {if (map.size >= this.capacity) {// 缓存容量已满,移除尾部节点const leastUsedKey = this.tail.prev.key;this._removeNode(this.tail.prev);map.delete(leastUsedKey);}// 创建新节点,和更新 HashMap,并移动到链表头部const newNode = this._addNode({ key, value });map.set(key, newNode);}}// 双向链表删除节点_removeNode(node) {node.prev.next = node.next;node.next.prev = node.prev;}// 删除双向链表旧节点位置,然后移动到头部_moveToHead(node) {this._removeNode(node);this._addNode(node);}// 添加节点并移动到头部_addNode(node) {node.prev = this.head;node.next = this.head.next;this.head.next.prev = node;this.head.next = node;return node;}
}// 使用示例
const cache = new LRUCache(2);
cache.put(1, 10);
console.log(cache.get(1)); // 10
cache.put(2, 20);
cache.put(3, 30);
console.log(cache.get(1)); // -1
http://www.tj-hxxt.cn/news/38401.html

相关文章:

  • 网站公安备案需要几个工作日互联网广告平台代理
  • 用dede做的网站首页广州网站优化公司如何
  • 个人网站下载昆明seo博客
  • 长沙做网站开发价格查网站关键词工具
  • robot.txt wordpress南京百度关键字优化价格
  • 网站滚动字幕怎么做营销策略
  • 免费企业网站cms系统上海最新新闻事件今天国内
  • 厦门效果图制作公司高明公司搜索seo
  • 景德镇做网站的公司百度投诉中心入口
  • 网站建设大概多少费用北京seo关键词排名优化
  • 自己网站做seo百度公司官网首页
  • 常州网站制作czyzj深圳网站设计实力乐云seo
  • wordpress 子主题 样式乐陵市seo关键词优化
  • 成都建设网站首页公司宣传网站制作
  • 电影网站开发任务书网站seo方案案例
  • wordpress 插件站百度实时热点排行榜
  • 网站制作动态转静态怎么做北京seo做排名
  • 东莞建设培训中心网站seo完整教程视频教程
  • 信息化建设办公室网站推广赚钱的平台有哪些
  • 万网购买网站吸引顾客的营销策略
  • wordpress获取页面tag南宁seo外包靠谱吗
  • 网页版游戏排行榜传奇石家庄百度推广优化排名
  • phpstudy怎么做网站口碑营销的重要性
  • 有了php源码怎么做网站jsurl转码
  • java网站开发属于什么职能优化网站排名公司
  • 找网站开发常见的网络营销推广方式有哪些
  • ps网站主页按钮怎么做百度网站推广价格查询
  • 南京 网站建设线上宣传方式有哪些
  • 网站子域名长春seo培训
  • 怎么建企业自己的网站吗百度一下点击搜索