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

织梦做的网站图片显示不了广州市网站建设科技公司

织梦做的网站图片显示不了,广州市网站建设科技公司,装wordpress需要配置apache,电商销售渠道有哪些146.LRU缓存 方法一#xff1a;哈希表双向链表 使用一个哈希表和一个双向链表维护所有在缓存中的键值对 双向链表按照被使用的顺序存储了这些键值对#xff0c;靠近头部的键值对是最近使用的#xff0c;而靠近尾部的键值对是最久使用的哈希表即为普通的哈希映射#xff0…146.LRU缓存 方法一哈希表双向链表 使用一个哈希表和一个双向链表维护所有在缓存中的键值对 双向链表按照被使用的顺序存储了这些键值对靠近头部的键值对是最近使用的而靠近尾部的键值对是最久使用的哈希表即为普通的哈希映射通过缓存数据的键映射到其在双向链表中的位置 这样以来我们首先使用哈希表进行定位找出缓存项在双向链表中的位置随后将其移动到双向链表的头部即可在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 MapInteger,DLinkedNode cache new HashMapInteger,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.dnsts.com.cn/news/192021.html

相关文章:

  • 建行手机网站wordpress+下载站
  • 山东省建设执业资格注册中心网站网页空间结构
  • 十堰优化网站排名公司wordpress 素材
  • 佛山正规网站建设哪家好完整网站开发视频
  • 怎么用indesign做网站设计网站建设找丿金手指排名
  • 做任务的兼职网站西安旅游攻略3天花费
  • 怎么找网站后台备案期间关网站吗
  • 前端网站优化出入南京最新通知今天
  • 中国交通建设集团官方网站个人网站管理系统
  • 济南网站建设知识区块链开发需要什么技术
  • 网站建设结构深圳住房和建设局网站统一
  • 公众号做淘宝客接入手机网站南京科技网站设计有特点
  • 开原铁岭网站建设网站页面组成部分
  • 微信公众号内嵌网站开发简单网页制作模板源代码
  • 哪家做网站公司好做网站的标准流程
  • 找人做软件网站网站建设属于哪个税收服务编码
  • 建设部网站水利造价师云南建设项目审批中心网站
  • 做视频解析网站要什么服务器长沙百度快速优化
  • 济南网站建设大标网络庆阳网站设计 贝壳下拉
  • 如何进入网站后台 被黑怎样注册一个自己的网站
  • 网站式登录页面模板下载网站做用户记录
  • 汉邦未来网站开发有限公司域名问题网站不更新
  • 义乌网站建设zisou8沈阳seo网站推广优化
  • 做外贸网站义乌wordpress标签插件
  • 德阳建设机械网站企业网站的建立不能缺少哪些细节
  • 软件公司网站设计与制作卖主机网站
  • 淘宝网站开发的多少钱素材网站推广方案
  • 优秀的网站有哪些商品展示介绍网站源码
  • a站是啥百度代做seo排名
  • 长沙做网站的公司有哪些旅游型网站建设