【Leetcode 每日一题】146. LRU 缓存(c++)
146. LRU 缓存
请你设计并实现一个满足 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) 的平均时间复杂度运行。
示例:
输入
["LRUCache", "put", "put", "get", "put", "get", "put", "get", "get", "get"]
[[2], [1, 1], [2, 2], [1], [3, 3], [2], [4, 4], [1], [3], [4]]
输出
[null, null, null, 1, null, -1, null, -1, 3, 4]解释
LRUCache lRUCache = new LRUCache(2);
lRUCache.put(1, 1); // 缓存是 {1=1}
lRUCache.put(2, 2); // 缓存是 {1=1, 2=2}
lRUCache.get(1); // 返回 1
lRUCache.put(3, 3); // 该操作会使得关键字 2 作废,缓存是 {1=1, 3=3}
lRUCache.get(2); // 返回 -1 (未找到)
lRUCache.put(4, 4); // 该操作会使得关键字 1 作废,缓存是 {4=4, 3=3}
lRUCache.get(1); // 返回 -1 (未找到)
lRUCache.get(3); // 返回 3
lRUCache.get(4); // 返回 4
提示:
1 <= capacity <= 30000 <= key <= 100000 <= value <= 105- 最多调用
2 * 105次get和put
思考:
// # 键值对--哈希表
// # 出入顺序--栈、队列、链表
// # 随机访问,插入头部或者尾部--双向链表 O(1)
// # 包括插入、移动、删除
使用一个哈希表来存储键和它们对应的值以及在双向链表中的位置,同时使用一个双向链表来维护键的最近使用顺序。在执行get操作时,如果键存在,则将其对应的节点移动到双向链表的末尾,表示最近被访问;在执行put操作时,如果键已存在,则更新其值并移动到链表末尾,如果键不存在,则检查缓存是否已满,若已满则从链表头部移除最久未使用的键,然后添加新键值对到缓存中。这样,通过结合哈希表的快速查找和双向链表的顺序维护,实现了平均时间复杂度为O(1)的LRU缓存机制。
参考代码(c++):
class LRUCache {// # 键值对--哈希表// # 出入顺序--栈、队列、链表// # 随机访问,插入头部或者尾部--双向链表// # 包括插入、移动、删除
private:int capacity0; // 缓存的容量list<int> keyList; // 用于维护键的顺序,最近使用的在末尾unordered_map<int, pair<int, list<int>::iterator>> hashMap; // 哈希表,存储键、值和键在keyList中的迭代器public:LRUCache(int capacity) {capacity0 = capacity; // 初始化缓存容量}int get(int key) {auto it = hashMap.find(key); // 在哈希表中查找键if(it != hashMap.end()){ // 如果找到了键keyList.erase(it->second.second); // 从keyList中移除旧的键keyList.push_back(key); // 将键重新添加到keyList的末尾,表示最近被访问hashMap[key].second = (--keyList.end()); // 更新哈希表中的迭代器,指向新的末尾位置return it->second.first; // 返回键对应的值}return -1; // 如果键不存在,返回-1}void put(int key, int value) {if(hashMap.find(key) != hashMap.end()){ // 如果键已经存在hashMap[key].first = value; // 更新键对应的值keyList.erase(hashMap[key].second); // 从keyList中移除旧的键keyList.push_back(key); // 将键重新添加到keyList的末尾hashMap[key].second = (--keyList.end()); // 更新哈希表中的迭代器,指向新的末尾位置return; // 更新完成后返回}if(hashMap.size() < capacity0){ // 如果当前缓存大小小于容量Insert(key, value); // 调用Insert函数插入新的键值对}else{int removeKey = keyList.front(); // 获取并移除keyList中的第一个元素(最久未使用的键)keyList.pop_front(); // 从keyList中移除第一个元素hashMap.erase(removeKey); // 从哈希表中移除对应的键值对Insert(key, value); // 插入新的键值对}}// 插入或更新键值对的辅助函数void Insert(int key, int value){keyList.push_back(key); // 将键添加到keyList的末尾hashMap[key] = make_pair(value, --keyList.end()); // 在哈希表中添加键值对和迭代器}
};/*** 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);*/
相关文章:
【Leetcode 每日一题】146. LRU 缓存(c++)
146. LRU 缓存 请你设计并实现一个满足 LRU (最近最少使用) 缓存 约束的数据结构。 实现 LRUCache 类: LRUCache(int capacity) 以 正整数 作为容量 capacity 初始化 LRU 缓存int get(int key) 如果关键字 key 存在于缓存中,则返回关键字的值&#x…...
【机器学习】近似分布的熵到底是p(x)lnq(x)还是q(x)lnq(x)?
【1】通信的定义 信息量(Information Content)是信息论中的一个核心概念,用于定量描述一个事件发生时所提供的“信息”的多少。它通常用随机变量 𝑥的概率分布来定义。事件 𝑥发生所携带的信息量由公式给出࿱…...
网络安全,文明上网(6)网安相关法律
列举 1. 《中华人民共和国网络安全法》: - 这是中国网络安全的基本法律,于2017年6月1日开始实施。该法律明确了网络运营者的安全保护义务,包括采取数据分类、重要数据备份和加密等措施。 2. 《中华人民共和国数据安全法》: …...
网络安全学习74天(记录)
11.21日,今天学习了 app抓包(需要的工具charles(激活),夜神模拟器,postern,) 思路:首先charles需要抓取的app的包,需要的是装证书,将charles的证…...
Spring Boot 实战:基于 Validation 注解实现分层数据校验与校验异常拦截器统一返回处理
1. 概述 本文介绍了在spring boot框架下,使用validation数据校验注解,针对不同请求链接的前端传参数据,进行分层视图对象的校验,并通过配置全局异常处理器捕获传参校验失败异常,自动返回校验出错的异常数据。 2. 依赖…...
20241125复盘日记
昨日最票: 南京化纤 滨海能源 广博股份 日播时尚 众源新材 返利科技 六国化工 丰华股份 威领股份 凯撒旅业 华扬联众 泰坦股份 高乐股份高均线选股: 理邦仪器高乐股份日播时尚领湃科技威领股份资金最多的票: 资金攻击最多的票: …...
【Excel】拆分多个sheet,为单一表格
Private Sub 分拆工作表() Application.ScreenUpdating True 让屏幕显示操作过程, Dim sht As Worksheet Dim MyBook As Workbook Set MyBook ActiveWorkbook For Each sht In MyBook.Sheets If sht.Visible True Then 隐藏的sheet跳过,否则会报1004无…...
类和对象plus版
一.类的定义 1.1类定义的格式 图中class为关键字,Stack为类的名字,用{}框住类的主体,类定义完后;不能省略。 为了区分成员变量,一般习惯在成员变量前面或后面加一个特殊标识,_或者m_ 1.2访问限定符 c采用…...
shell练习
开篇小贴士:为创建的sh(当然可以是任何一个文件)文件添加开头的注释 1、进入到家目录,然后通过 ls -a 查看全部文件 2、找到并编辑一个名为 .vimrc (Vim编辑器的核心配置文件)的配置文件,下图…...
ApiChain 从迭代到项目 接口调试到文档生成单元测试一体化工具
项目地址:ApiChain 项目主页 ApiChain 简介 ApiChain 是一款类似 PostMan 的接口网络请求与文档生成软件,与 PostMan 不同的是,它基于 项目和迭代两个视角管理我们的接口文档,前端和测试更关注版本迭代中发生变更的接口编写代码…...
Vercel 设置自动部署 GitHub 项目
Vercel 设置自动部署 GitHub 项目 问题背景 最近 Vercel 调整了其部署政策,免费版用户无法继续使用自动部署功能,除非升级到 Pro 计划。但是,我们可以通过配置 Deploy Hooks 来实现同样的自动部署效果。 解决方案 通过设置 Vercel 的 Dep…...
SQL进阶:如何跳过多个NULL值取第一个非NULL值?
NULL 一、问题描述二、ORACLE<一>、last_value () over ()<二>、lag () over()<三>、相关子查询 三、MYSQL<一>、全局变量<二>、coalesce() lag() over()<三>、相关子查询<四>、 recursive<五>、lag() over() min() over() …...
laravel 5.5 增加宏指令 joinSub, 省去->toSql() 和 addBinding($bindings);
laravel 5.5 增加宏指令 joinSub, 省去->toSql() 和 addBinding($bindings); 1. 在laravel5使用join 子查询时 $sub_query DB::table(table1)->select([table1.id, cate_id])->join(table2, table1.id, , table2.id)->where(table1.cate_id, 2)->orderBy(tabl…...
远程控制软件:探究云计算和人工智能的融合
在数字化时代,远程控制工具已成为我们工作与生活的重要部分。用户能够通过网络远程操作和管理另一台计算机,极大地提升了工作效率和便捷性。随着人工智能(AI)和云计算技术的飞速发展,远程控制工具也迎来了新的发展机遇…...
网络协议之DNS
一、DNS概述 域名系统(Domain Name System,缩写:DNS)是互联网的一项服务。它作为将域名和IP地址相互映射的一个分布式数据库,能够使人更方便地访问互联网。DNS使用TCP和UDP端口53,通过递归查询请求的方式来…...
.net6 使用 FreeSpire.XLS 实现 excel 转 pdf - docker 部署
FreeSpire.XLS && Aspose.Cells包都可以实现。实现过程中发现如下问题: 本地测试通过, docker部署服务器后报错: The type initializer for Spire.Xls.Core.Spreadsheet.XlsPageSetupBase threw an exception. 由于缺少依赖…...
QML学习 —— 28、3种等待指示控件(附源码)
效果如下 说明 BusyIndicator应用于指示在加载内容或UI被阻止等待资源可用时的活动。BusyIndicator类似于一个不确定的ProgressBar。两者都可以用来指示背景活动。主要区别在于视觉效果,ProgressBar还可以显示具体的进度(当可以确定时)。由于视觉差异,繁忙指示器和不确定的…...
flutter 专题十一 Fair原理篇Fair逻辑动态化架构设计与实现
数据逻辑处理布局中的逻辑处理Flutter类型数据处理 一、数据逻辑处理 我们接触的每一个Flutter界面,大多由布局和逻辑相关的代码组成。如Flutter初始工程的Counting Demo的代码: class _MyHomePageState extends State<MyHomePage> {// 变量 in…...
利用开源图床的技巧与实践
随着互联网的普及,图片的使用变得越来越广泛。无论是个人博客、社交媒体还是企业网站,都离不开图片的呈现。而图床作为图片存储和管理的工具,可以帮助开发者和内容创作者高效地管理图片资源。本文将探讨如何利用开源图床,并提供相…...
C++数据结构与算法
C数据结构与算法 1.顺序表代码模版 C顺序表模版 #include <iostream> using namespace std; // 可以根据需要灵活变更类型 #define EleType intstruct SeqList {EleType* elements;int size;int capacity; };// Init a SeqList void InitList(SeqList* list, int capa…...
别再混淆了!一文讲透W25Q128FV与JV的QSPI驱动差异(附STM32H743配置代码)
深入解析W25Q128FV与JV的QSPI驱动差异及STM32H743实战配置 在嵌入式存储解决方案中,W25Q128系列闪存芯片因其高性价比和稳定性能而广受欢迎。然而,许多工程师在实际项目中容易忽略FV与JV这两个子型号之间的关键差异,导致驱动开发过程中出现各…...
免费开源质谱数据分析工具MZmine:从原始数据到科学发现的完整解决方案
免费开源质谱数据分析工具MZmine:从原始数据到科学发现的完整解决方案 【免费下载链接】mzmine3 mzmine source code repository 项目地址: https://gitcode.com/gh_mirrors/mz/mzmine3 你是否曾为昂贵的商业质谱分析软件而烦恼?是否在寻找一款功…...
对比实测不同模型通过统一API调用的响应延迟体感
🚀 告别海外账号与网络限制!稳定直连全球优质大模型,限时半价接入中。 👉 点击领取海量免费额度 对比实测不同模型通过统一API调用的响应延迟体感 在开发过程中,当我们接入多个大模型服务时,一个直观的体验…...
Python异步Web框架SerpentStack:高性能API服务开发指南
1. 项目概述:SerpentStack,一个被低估的Python异步Web框架最近在GitHub上闲逛,又看到了一个名为“SerpentStack”的Python Web框架项目,作者是Benja-Pauls。说实话,第一眼看到这个名字,我差点把它归为又一个…...
跨境电商AI Agent技术拆解:从RPA到智能体,店铺自动化运营的架构与实践
当大模型“驱动”RPA,跨境电商运营正在从“脚本自动化”迈向“意图驱动”的数字员工时代 写在前面 跨境电商卖家每天面对多平台(Amazon、eBay、TikTok、Temu、Shopee等)、多店铺、多站点,运营工作高度重复:采集竞品数…...
TuxGuitar:终极免费吉他谱编辑软件完全指南,新手快速上手攻略
TuxGuitar:终极免费吉他谱编辑软件完全指南,新手快速上手攻略 【免费下载链接】tuxguitar Open source guitar tablature editor 项目地址: https://gitcode.com/gh_mirrors/tu/tuxguitar 你是否在寻找一款功能强大且完全免费的吉他谱编辑软件&am…...
华硕笔记本性能优化终极指南:3步告别臃肿控制软件,用G-Helper重获流畅体验
华硕笔记本性能优化终极指南:3步告别臃肿控制软件,用G-Helper重获流畅体验 【免费下载链接】g-helper Lightweight Armoury Crate alternative for Asus laptops with nearly the same functionality. Works with ROG Zephyrus, Flow, TUF, Strix, Scar,…...
5分钟掌握Windows窗口置顶神器:PinWin完整使用指南
5分钟掌握Windows窗口置顶神器:PinWin完整使用指南 【免费下载链接】PinWin Pin any window to be always on top of the screen 项目地址: https://gitcode.com/gh_mirrors/pin/PinWin Windows窗口置顶工具PinWin是一款让你彻底告别频繁窗口切换的神器。无论…...
GPT-5级能力提前落地,ChatGPT 2026新增9大生产级功能,含RAG++动态知识图谱、零样本工作流编排、联邦学习微调接口——错过本轮升级将落后至少18个月
更多请点击: https://intelliparadigm.com 第一章:GPT-5级能力提前落地的技术本质与产业影响 当前,所谓“GPT-5级能力”并非依赖单一巨型模型发布,而是通过模型蒸馏、多专家协同推理(MoE)、实时知识注入与…...
夏普鸿海合作破裂启示:跨文化并购中的技术控制与信任危机
1. 一场被寄予厚望的“联姻”为何走向破裂?2012年3月,当日本液晶面板巨头夏普宣布与全球最大电子代工企业鸿海(富士康)达成资本合作时,整个东亚电子产业圈都为之震动。这被视为一个标志性事件:一家以技术自…...
