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

月刊可以用什么网站做网页开发软件有哪些

月刊可以用什么网站做,网页开发软件有哪些,wordpress 三大标签,27岁了想学网站建设前言: 请你设计并实现一个满足 LRU (最近最少使用) 缓存 约束的数据结构。 实现 LRUCache 类: LRUCache(int capacity) 以 正整数 作为容量 capacity 初始化 LRU 缓存int get(int key) 如果关键字 key 存在于缓存中,则返回关键字的值&…

前言:

请你设计并实现一个满足  LRU (最近最少使用) 缓存 约束的数据结构。

实现 LRUCache 类:

  • LRUCache(int capacity) 以 正整数 作为容量 capacity 初始化 LRU 缓存
  • int get(int key) 如果关键字 key 存在于缓存中,则返回关键字的值,否则返回 -1 。
  • void put(int key, int value) 如果关键字 key 已经存在,则变更其数据值 value ;如果不存在,则向缓存中插入该组 key-value 。如果插入操作导致关键字数量超过 capacity ,则应该 逐出 最久未使用的关键字。
  • 函数 get 和 put 必须以 O(1) 的平均时间复杂度运行。

关键设计说明

  1. 双向链表:维护访问顺序

    • 头部节点 (head.next):最近使用的数据

    • 尾部节点 (end.prev):最久未使用的数据

    • 节点移动/删除操作都是 O(1) 时间复杂度

  2. 哈希表:提供 O(1) 的键值查找

    • Map<Integer, DLinkedNode> 映射键到链表节点

    • 快速判断键是否存在并获取对应节点

  3. 哨兵节点:简化边界处理

    • 头节点 (head) 和尾节点 (end) 作为虚拟节点

    • 避免空指针检查,使代码更简洁

  4. 操作流程

    • get():存在则移动节点到头部

    • put()

      • 存在 → 更新值并移到头部

      • 不存在 → 创建新节点并添加到头部

      • 容量超限 → 移除尾部节点

复杂度分析

  • 时间复杂度get() 和 put() 均为 O(1)

    • 哈希表操作:O(1) 的查找/插入/删除

    • 链表操作:O(1) 的节点添加/删除/移动

代码实现:

import java.util.HashMap;
import java.util.Map;
class LRUCache {//双向链表class DLinkedNode{int key;int value;DLinkedNode prev;DLinkedNode next;public DLinkedNode(){}public DLinkedNode(int key,int value){this.key = key;this.value = value;}}//LRU缓存的属性//容量private int capacity = 0;//实际个数private int size = 0;//map装的key,node节点private final Map<Integer,DLinkedNode> cache = new HashMap();//链表前后节点哨兵,方便操作头尾。private final DLinkedNode head = new DLinkedNode();private final DLinkedNode end = new DLinkedNode();//初始化缓存public LRUCache(int capacity) {//不仅仅是赋值还要初始化链表//头尾节点互相指向head.next = end;end.prev = head;this.capacity = capacity;}public int get(int key) {//得到nodeDLinkedNode node = cache.get(key);//判断是否存在,存在就添加到链表头部if(node==null){return -1;}moveToNode(node);return node.value;}public void put(int key, int value) {DLinkedNode node = cache.get(key);if(node!=null){//已经存在就重新赋值node.value = value;moveToNode(node);}else{//不存在就要新建一个节点,在放入mapDLinkedNode Newnode = new DLinkedNode(key,value);cache.put(key,Newnode);addToTop(Newnode);size++;}//判断是否溢出if(size>capacity){//移除最后一个元素DLinkedNode endnode = end.prev;removeEndNode(endnode);}}//辅助方法//添加到链表头部public void addToTop(DLinkedNode node){node.prev = head;head.next.prev = node;node.next = head.next;head.next = node;}//移动链表到头部public void moveToNode(DLinkedNode node){removeNode(node);addToTop(node);}//移除nodepublic void removeNode(DLinkedNode node){node.next.prev = node.prev;node.prev.next = node.next;}//移除最后一个元素,还要清除hashpublic void removeEndNode(DLinkedNode node){removeNode(node);cache.remove(node.key);size--;}
}

总结

本人是一个菜鸟,没怎么刷算法题,这算是我第一次刷算法题,不过基本的数据结构我还是会,这道题我是直接问的ai因为我完全没有思路,觉得这个很难,然后看了ai的解法,和思路,感觉非常清晰,就去自己动手写了一遍,一次过,很有成就感,后续也会继续刷题。

如果我的文章成功帮助了你,请点赞加关注,你们的支持是我最大的动力。

http://www.dtcms.com/a/424082.html

相关文章:

  • Coze源码分析-资源库-编辑插件-后端源码-领域/数据访问层
  • 【python】函数进阶
  • 河南便宜网站建设价格制作网页图片格式
  • 如何将文件从电脑传输到安卓设备
  • 3分钟了解k8s中kube-proxy组件的作用--图文篇
  • GEO 优化工具怎么选?助力品牌进入 AI 推荐清单的实用指南
  • C++学习 - 内存管理
  • Preemption
  • 一个网站两个域名备案河南周口东宇网站建设
  • 词向量:从 One-Hot 到 BERT Embedding,NLP 文本表示的核心技术
  • 3DGS 如何理解它?
  • 北京的网站建设公司有哪些wordpress 删除 加载中
  • 从PHP到Spring Boot:思维的转变与入门实战 (指南二)
  • 宁波网络公司网站建设项目网站开发人员职位描述
  • 串扰05-远端串扰的饱和
  • 湖南网站推广免费开源企业cms
  • 句容网站开发wordpress页面输入密码
  • 深入理解 Java 并发编程:从理论到实践的全面指南
  • 网站需求分析有哪些内容仿牌网站专用vps
  • 做网站超速云佛山市seo网站设计工具
  • 网站开发服务器怎么选wordpress黑白主题
  • Product Hunt 每日热榜 | 2025-09-29
  • 国外设交网站开发客户的重要性中国互联网公司排名2022
  • 目标检测: yolov6算法在RK3588上部署
  • 做网站的分辨率h5网站的好处
  • Docker 容器无法访问外网的问题排查与解决指南
  • 青岛 网站科技公司模板做的网站不好优化
  • DataLab 平台亮相 MAIC 2025医学人工智能大会,和鲸助力同济医院构建医学 AI 科研新基础设施
  • 如何制作建筑公司网站手机端网页制作公司
  • 个人学习专用:Delphi 13 Florence 安装(含C++ Builder13)x64+x32