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

山东公司网站建设营销型网站有哪些功能

山东公司网站建设,营销型网站有哪些功能,做国际物流需要自己的网站吗,做一级域名网站多少钱146.LRU缓存 方法一:哈希表双向链表 使用一个哈希表和一个双向链表维护所有在缓存中的键值对 双向链表按照被使用的顺序存储了这些键值对,靠近头部的键值对是最近使用的,而靠近尾部的键值对是最久使用的哈希表即为普通的哈希映射&#xff0…

146.LRU缓存

image-20231103194750082

方法一:哈希表+双向链表

使用一个哈希表和一个双向链表维护所有在缓存中的键值对

  • 双向链表按照被使用的顺序存储了这些键值对,靠近头部的键值对是最近使用的,而靠近尾部的键值对是最久使用的
  • 哈希表即为普通的哈希映射,通过缓存数据的键映射到其在双向链表中的位置

这样以来,我们首先使用哈希表进行定位,找出缓存项在双向链表中的位置,随后将其移动到双向链表的头部,即可在O(1)的时间内完成get或者put操作,具体方法如下:

  • 对于get操作,首先判断key是否存在

    • 如果key不存在,则返回-1
    • 如果key存在,则key对应的节点是最近被使用的节点,通过哈希表定位到该节点在双向链表中的位置,并将其移动到双向链表的头部, 最后返回该节点的值
  • 对于put操作,首先判断key是否存在

    • 如果key不存在,使用key和value创建一个新的节点,在双向链表的头部添加该节点,并将key和该节点添加进哈希表中,然后判断双向链表的节点数是否超出容量,如果超出容量,则删除双向链表的尾部节点,并删除哈希表中对应的项
    • 如果key存在,则与get操作类似,先通过哈希表定位,再将对应的节点的值更新为value,并将该节点移到双向链表的头部
class LRUCache {class DLinkedNode{int key;int value;DLinkedNode prev;DLinkedNode next;public DLinkedNode(){}public DLinkedNode(int _ket,int _value){key = _ket;value = _value;}}private Map<Integer,DLinkedNode> cache = new HashMap<Integer,DLinkedNode>();private int size;private int capacity;private DLinkedNode head,tail;public LRUCache(int capacity) {this.size = 0;this.capacity = capacity;//使用伪头部和伪尾部节点head = new DLinkedNode();tail = new DLinkedNode();head.next = tail;tail.prev = head;}public int get(int key) {DLinkedNode node = cache.get(key);if(node == null){return -1;}//如果key存在,先通过哈希表定位,再移到头部moveToHead(node);return node.value;}public void put(int key, int value) {DLinkedNode node = cache.get(key);if(node == null){//如果key不存在,创建一个新节点DLinkedNode newNode = new DLinkedNode(key,value);//添加进哈希表cache.put(key,newNode);//添加至双向链表的头部addToHead(newNode);++size;if(size > capacity){//如果超出容量,删除双向链表的尾部节点DLinkedNode tail = removeTail();//删除哈希表中对应的项cache.remove(tail.key);--size;}}else{//如果key存在,先通过哈希表定位,再修改value,并移到头部node.value = value;moveToHead(node);}}private void addToHead(DLinkedNode node){node.prev = head;node.next = head.next;head.next.prev = node;head.next = node;}private void removeNode(DLinkedNode node){node.prev.next = node.next;node.next.prev = node.prev;}private void moveToHead(DLinkedNode node){removeNode(node);addToHead(node);}private DLinkedNode removeTail(){DLinkedNode res = tail.prev;removeNode(res);return res;}}/*** Your LRUCache object will be instantiated and called as such:* LRUCache obj = new LRUCache(capacity);* int param_1 = obj.get(key);* obj.put(key,value);*/
http://www.khdw.cn/news/22463.html

相关文章:

  • 郑州高档网站建设企业宣传推广方案
  • 地方门户网站源码网站设计制作培训
  • 网站所用的图片大小搜狗优化排名
  • 镇平县建设局网站营销云
  • 网站制作的常见问题外贸营销型网站建设公司
  • 行业网站的优势网站建设网络营销
  • 广州做营销型网站建设宁波seo网络推广报价
  • 网站域名云服务器是什么最近一周的新闻
  • 深圳华强北现在能去吗厦门关键词排名seo
  • 企业建站系统平台站长工具亚洲
  • 武汉外贸建站徐州百度快照优化
  • 龙岗成交型网站建设黑帽seo技术有哪些
  • 广州天河区有哪些大学短视频seo软件
  • wordpress通用页面模板下载企业seo优化服务
  • 做详情页上什么网站找素材网站优化招聘
  • 宽创国际的展馆设计案例seo快照推广
  • 江阴建设局官方网站今日新闻热点大事件
  • 怎么知道公司网站是哪个公司做的淄博网站营销与推广
  • 中国十大做网站公司seo综合查询怎么用的
  • 海口网站建设方案推广营销技巧培训ppt
  • 仿站网站宁波网络推广优化公司
  • 做网站设计工资多少钱网店代运营可靠吗
  • 企业手机网站杭州排名优化公司电话
  • 毕业论文的网站做营销网站建站公司
  • 武汉网站建设与服务公司电商数据网站
  • 绍兴市住房和城乡建设局网站南京最新消息今天
  • 潍坊400建网站公司2023智慧树网络营销答案
  • 做汽车导航仪在什么网站找客户南京关键词seo公司
  • 做网站用的语言百度小说排名
  • 网页小游戏链接优化