算法-数据结构

算法-数据结构

金无足赤人无完人,在处理实际问题的时候我们可以使用到很多合适的数据结构,但目前还没有一个数据结构可以称的上完美。查询速度快的,插入的速度就会慢;插入速度和查询速度都快得,占用的空间就会多;占用空间少的,可能会牺牲查询或插入的速度。
所以我们要在不同的问题使用合适的数据结构,就像大家在找对象的时候,他/她不一定是最完美的,但一定是适合你的,希望大家都能找到合适的对象~

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 ,则应该 逐出 最久未使用的关键字。
分析
  1. 函数 getput 必须以 O(1) 的平均时间复杂度运行。
  2. 能支持 get O(1) 的有哈希表、数组,支持 put O(1) 的有可变数组的末尾元素、哈希表、双向链表
  3. 因为put的对象需要是最不长使用的数据,没有要确保最不长使用的数据快速被找的,所以使用的是链表,链表可以快速更新节点位置
class DLinkNode():def __init__(self, key=0, val=0):self.key = keyself.val = valself.next = Noneself.prev = Noneclass LRUCache:def __init__(self, capacity: int):self.size = 0self.capacity = capacityself.head = DLinkNode()self.tail = DLinkNode()# 虚拟头节点,尾节点self.head.next = self.tailself.tail.prev = self.headself.cache = dict()def get(self, key: int) -> int:if key in self.cache:node = self.cache[key]# 更新头节点self.remove_node(node)self.add_to_head(node)return node.valelse:return -1def put(self, key: int, value: int) -> None:if key in self.cache:node = self.cache[key]node.val = valueself.remove_node(node)self.add_to_head(node)else:node = DLinkNode(key, value)self.add_to_head(node)self.cache[key] = nodeself.size += 1if self.size > self.capacity:self.del_tail_node()self.size -= 1# 删除节点 O(1)def remove_node(self, node):node.next.prev = node.prevnode.prev.next = node.next# 更新头节点def add_to_head(self, node):node.next = self.head.nextself.head.next = nodenode.prev = self.headnode.next.prev = node# 删除尾节点def del_tail_node(self):node = self.tail.prevself.tail.prev = node.prevself.tail.prev.next = self.tailself.cache.pop(node.key)# Your LRUCache object will be instantiated and called as such:
# obj = LRUCache(capacity)
# param_1 = obj.get(key)
# obj.put(key,value)

155. 最小栈

设计一个支持 pushpoptop 操作,并能在常数时间内检索到最小元素的栈。

实现 MinStack 类:

  • MinStack() 初始化堆栈对象。
  • void push(int val) 将元素val推入堆栈。
  • void pop() 删除堆栈顶部的元素。
  • int top() 获取堆栈顶部的元素。
  • int getMin() 获取堆栈中的最小元素。

分析

  1. push pop top可通过变长数组完成
  2. getMin() 是关键, 我们可以通过另一个变长数组记录当前的最小值
    • 记录数组a=[4,5,6,2,3,1]
    • 最小值数组b=[4,4,4,2,2,1]
    • 差值记录a=[0,1,2,-2,1,-1]:前一个最小值可以通过当前最小值减去记录数组的值:1-(-1)= 2;2-(-2)= 4。具体可看代码
class MinStack:def __init__(self):# 记录差值self.stack = []# 记录最小值self.min_: intdef push(self, val: int) -> None:if not self.stack:# 差值为0,最小值为valself.stack.append(0)self.min_ = valelse:diff = val - self.min_self.stack.append(diff)# 差值小于零,更新最小值if diff < 0:self.min_ = valdef pop(self) -> None:pop_ = self.stack.pop()# 说明是最小值if pop_ < 0:ret = self.min_self.min_ += -pop_return retelse:return self.min_ + pop_def top(self) -> int:if self.stack[-1] <= 0:return self.min_else:return self.min_ + self.stack[-1]def getMin(self) -> int:return self.min_

380. O(1) 时间插入、删除和获取随机元素

实现RandomizedSet 类:

  • RandomizedSet() 初始化 RandomizedSet 对象
  • bool insert(int val) 当元素 val 不存在时,向集合中插入该项,并返回 true ;否则,返回 false
  • bool remove(int val) 当元素 val 存在时,从集合中移除该项,并返回 true ;否则,返回 false
  • int getRandom() 随机返回现有集合中的一项(测试用例保证调用此方法时集合中至少存在一个元素)。每个元素应该有 相同的概率 被返回。

你必须实现类的所有函数,并满足每个函数的 平均 时间复杂度为 O(1)

  1. insert remove 可通过哈希表,变成数组末尾、链表末尾实现
  2. getRandom() 只能通过数组实现,因为数组可以直接取数且任意一个元素出现概率是相等的

用哈希表记录元素下标,删除时将删除元素与末尾元素交换,这样就相对于删除末尾元素了

class RandomizedSet:def __init__(self):self.arr = []self.dic = dict()def insert(self, val: int) -> bool:if val in self.dic:return Falseidx = len(self.arr)self.dic[val] = idxself.arr.append(val)return Truedef remove(self, val: int) -> bool:if val not in self.dic:return Falseidx = self.dic[val]self.arr[idx] = self.arr[-1]self.dic[self.arr[idx]] = idxself.arr.pop()self.dic.pop(val)return Truedef getRandom(self) -> int:return choice(self.arr)

2671. 频率跟踪器

211. 添加与搜索单词 - 数据结构设计

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/770898.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

PTAxt的考研路

xt是我院19级专业第一&#xff0c;但他认为保研并不能展示他全部的实力&#xff0c;所以他在22年初试一结束就加入了23考研的队伍中&#xff0c;并且他为了填补我院近些年来无北大研究生的空白&#xff0c;毅然决然决定扛起19级的大旗&#xff0c;在学校百年华诞之际献上他最诚…

Springboot项目之mybatis-plus多容器分布式部署id重复问题之源码解析

mybatis-plus 3.3.2 部署多个pod id冲突问题 配置&#xff1a; # 设置随机 mybatis-plus.global-config.worker-id: ${random.int(1,31)} mybatis-plus.global-config.datacenter-id: ${random.int(1,31)}源码解析&#xff1a;MybatisSqlSessionFactoryBean 重点&#xff1a…

mysql数据库查询

MYSQL数据库的搭建 今日目标&#xff1a; 1.搭建数据库 2.实现数据库的增删改查 00-回顾 #dos的常用指令 1. 切换盘符&#xff1a; 盘符名: 2. 切换上一级&#xff1a; cd ../ 3. 切换下一级&#xff1a; cd 目录名 4. 查看当前目录下的所有子目录和子文件&#xff1a; di…

光明源@智慧公厕赋能“厕所革命”主要体现在哪些方面?

当我们提及厕所&#xff0c;不再仅是简单的卫生设施&#xff0c;而是一种对生活品质的关怀与呵护。智慧公厕&#xff0c;作为厕所革命的引领者&#xff0c;以其独特的拟人魅力&#xff0c;彰显着人性化关怀的新风尚。今日&#xff0c;让我们一同探索&#xff0c;智慧公厕是如何…

数据库备份工具(实现数据定时覆盖)

数据库备份工具&#xff08;实现数据定时覆盖&#xff09; 永远热爱&#xff0c;永远执着&#xff01; 工具介绍 自动化测试数据库更新调度程序 这段 Python 脚本自动化了每天定时从生产数据库更新测试数据库的过程。它利用了 schedule 库来安排并执行每天指定时间的更新任务…

在for循环加判断条件当条件都满足时,同时显现的解决方法

一、代码示例 function fu(s) {str ;ste ;console.log(s);let Things s;for (let i 0; i < Things.length; i) {if (Things[i].pid kk) {console.log(Things[i].pid);ste <div class"commodity_nei"><div class"zxc_pic"><div cl…

[CISCN2019 总决赛 Day2 Web1]Easyweb ----不会编程的崽

CISCN的题质量还是很高的。 又是这熟悉的登陆界面。爆破&#xff1f;sql&#xff1f;还是xxe等。先看源码 估摸着也是sql注入。但似乎不是常规注入。同时扫描后台的结果应该也出来了&#xff0c;发现robots.txt 有点懵&#xff0c;后边看了大佬的wp才知道&#xff0c;提示的是*…

车载测试工具 canoe如何使用

其实canoe的使用非常的简单&#xff0c;结合自己的工作项目多多操作就可以了

openssl 升级1.1.1.1k 到 3.0.13

下载 https://www.openssl.org/source/ tar -zxvf openssl-3.0.13.tar.gzcd openssl-3.0.13/./config enable-fips --prefix/usr/local --openssldir/usr/local/opensslmake && make install 将原有openssl备份 mv /usr/bin/openssl /usr/bin/openssl.bak mv /usr/i…

LeetCode Python - 73. 矩阵置零

目录 题目描述解法方法一&#xff1a;数组标记方法二&#xff1a;原地标记 运行结果方法一方法二 题目描述 给定一个 m x n 的矩阵&#xff0c;如果一个元素为 0 &#xff0c;则将其所在行和列的所有元素都设为 0 。请使用 原地 算法。 示例 1&#xff1a; 输入&#xff1a;…

项目立项管理

目录 1.概述 2.项目建议与立项申请 3.项目可行性研究 3.1.内容 3.2.初步可行性研究 3.3.详细可行性研究 4.项目评估与决策 5.总结 1.概述 本文的目录结构参考了《信息系统项目管理师教程&#xff08;第四版&#xff09;》。 项目立项管理是一项全面评估准备投资工程的多…

Redis到底是多线程还是单线程?

Redis6.0之前&#xff1a;是单线程模式。 Redis6.0之后&#xff1a;Redis的IO线程是多线程&#xff0c;worker线程是单线程。 Redis6.0之前&#xff1a;单线程 Redis6.0之后&#xff1a;Redis的IO线程是多线程&#xff0c;worker线程是单线程。

适用于 Android 的 10 个优秀的数据恢复工具

在当今快节奏的数字时代&#xff0c;丢失 Android 设备中的重要数据可能是一场噩梦。无论是难忘的照片、重要的联系人还是重要的工作文档&#xff0c;您都需要一个可靠的恢复工具来恢复您的数据。值得庆幸的是&#xff0c;有许多高效的 Android 数据恢复工具可以帮助您恢复丢失…

【python】flask各种版本的项目,终端命令运行方式的实现

✨✨ 欢迎大家来到景天科技苑✨✨ &#x1f388;&#x1f388; 养成好习惯&#xff0c;先赞后看哦~&#x1f388;&#x1f388; &#x1f3c6; 作者简介&#xff1a;景天科技苑 &#x1f3c6;《头衔》&#xff1a;大厂架构师&#xff0c;华为云开发者社区专家博主&#xff0c;…

操作系统面经-多线程同步的四种方式

对于多线程程序来说&#xff0c;同步是指在一定的时间内只允许某一个线程来访问某个资源。而在此时间内&#xff0c;不允许其他的线程访问该资源。可以通过互斥锁&#xff08;Mutex&#xff09;、条件变量&#xff08;condition variable&#xff09;、读写锁&#xff08;reade…

XUbuntu22.04之跨平台日历工具(二百二十四)

简介&#xff1a; CSDN博客专家&#xff0c;专注Android/Linux系统&#xff0c;分享多mic语音方案、音视频、编解码等技术&#xff0c;与大家一起成长&#xff01; 优质专栏&#xff1a;Audio工程师进阶系列【原创干货持续更新中……】&#x1f680; 优质专栏&#xff1a;多媒…

ChatGPT编程秘籍:轻松学习人工智能写作

ChatGPT无限次数:点击直达 html ChatGPT编程秘籍&#xff1a;轻松学习人工智能写作 引言 人工智能技术的发展给写作领域带来了革命性的变化&#xff0c;其中自然语言生成&#xff08;NLG&#xff09;技术的发展尤为引人注目。ChatGPT是一款基于大规模预训练模型的人工智能…

数据结构与算法-排序算法

1.顺序查找 def linear_search(iters, val):for i, v in enumerate(iters):if v val:return ireturn 2.二分查找 # 升序的二分查找 def binary_search(iters, val):left 0right len(iters)-1while left < right:mid (left right) // 2if iters[mid] val:return mid…

300.【华为OD机试】跳房子I(时间字符串排序—JavaPythonC++JS实现)

本文收录于专栏:算法之翼 本专栏所有题目均包含优质解题思路,高质量解题代码(Java&Python&C++&JS分别实现),详细代码讲解,助你深入学习,深度掌握! 文章目录 一. 题目二.解题思路三.题解代码Python题解代码JAVA题解代码C/C++题解代码JS题解代码四.代码讲解(Ja…

WSL2 设置桥接模式

文章目录 一、前言二、准备阶段三、环境配置3.1 Type-V管理器环境配置3.2 新增.wslconfig 文件 四、遇到的问题以及解决方案 一、前言 ​ 使用 wsl 的过程中&#xff0c;会出现 WSL 的IP地址 找不到&#xff0c;或者无法和计算机通讯&#xff0c;搞 嵌入式 的话&#xff0c;还…