LeetCode 每日一题 2025/2/10-2025/2/16
记录了初步解题思路 以及本地实现代码;并不一定为最优 也希望大家能一起探讨 一起进步
目录
- 2/10 913. 猫和老鼠
- 2/11 1728. 猫和老鼠 II
- 2/12 1760. 袋子里最少数目的球
- 2/13 1742. 盒子中小球的最大数量
- 2/14 1552. 两球之间的磁力
- 2/15 1706. 球会落何处
- 2/16 1299. 将每个元素替换为右侧最大元素
2/10 913. 猫和老鼠
1.动态规划 (TLE)
dp[k][rat][cat] 第k轮表示老鼠位于rat位置 猫位于cat位置的游戏结果
dp[0][1][2]为初始状态的结果
老鼠进入0则老鼠获胜 dp[k][0][cat]=1
猫和老鼠同个位置猫获胜 dp[k][x][x] = 2 x!=0
如果k>=2n 平局 猫和老鼠必定走到了之前各自走过的位置 依旧无法取胜
2.拓扑排序
https://leetcode.cn/problems/cat-and-mouse/?envType=daily-question&envId=2025-02-10
def catMouseGame1(graph):""":type graph: List[List[int]]:rtype: int"""n = len(graph)dp = [[[-1]*n for _ in range(n)] for _ in range(2*n*n)]mem={}def find(r,c,k):if k==2*n*n:return 0res = dp[k][r][c]if res!=-1:return resif r==0:return 1elif r==c:return 2else:res = move(r,c,k)dp[k][r][c] = resreturn resdef move(rat,cat,k):if (rat,cat,k) in mem:return mem[(rat,cat,k)]cur = rat if k%2==0 else catdefaultRes = 1 if cur!=rat else 2 #老鼠回合默认猫赢res = defaultResfor loc in graph[cur]:if cur==cat and loc==0:continuenextR = loc if cur==rat else ratnextC = loc if cur==cat else catnextRes = find(nextR,nextC,k+1)if nextRes!=defaultRes: ##找到一个能够赢得即可res = nextResif res!=0:breakmem[(rat,cat,k)] = resreturn resreturn find(1,2,0)def catMouseGame2(graph):""":type graph: List[List[int]]"""import collectionsMOUSE_TURN = 0CAT_TURN = 1DRAW = 0MOUSE_WIN = 1CAT_WIN = 2n = len(graph)degrees = [[[0, 0] for _ in range(n)] for _ in range(n)]results = [[[0, 0] for _ in range(n)] for _ in range(n)]for i in range(n):for j in range(1, n):degrees[i][j][MOUSE_TURN] = len(graph[i])degrees[i][j][CAT_TURN] = len(graph[j])for y in graph[0]:for i in range(n):degrees[i][y][CAT_TURN] -= 1q = collections.deque()for j in range(1, n):results[0][j][MOUSE_TURN] = MOUSE_WINresults[0][j][CAT_TURN] = MOUSE_WINq.append((0, j, MOUSE_TURN))q.append((0, j, CAT_TURN))for i in range(1, n):results[i][i][MOUSE_TURN] = CAT_WINresults[i][i][CAT_TURN] = CAT_WINq.append((i, i, MOUSE_TURN))q.append((i, i, CAT_TURN))while q:mouse, cat, turn = q.popleft()result = results[mouse][cat][turn]if turn == MOUSE_TURN:prevStates = [(mouse, prev, CAT_TURN) for prev in graph[cat]]else:prevStates = [(prev, cat, MOUSE_TURN) for prev in graph[mouse]]for prevMouse, prevCat, prevTurn in prevStates:if prevCat == 0:continueif results[prevMouse][prevCat][prevTurn] == DRAW:canWin = result == MOUSE_WIN and prevTurn == MOUSE_TURN or result == CAT_WIN and prevTurn == CAT_TURNif canWin:results[prevMouse][prevCat][prevTurn] = resultq.append((prevMouse, prevCat, prevTurn))else:degrees[prevMouse][prevCat][prevTurn] -= 1if degrees[prevMouse][prevCat][prevTurn] == 0:results[prevMouse][prevCat][prevTurn] = CAT_WIN if prevTurn == MOUSE_TURN else MOUSE_WINq.append((prevMouse, prevCat, prevTurn))return results[1][2][MOUSE_TURN]
2/11 1728. 猫和老鼠 II
缓存lru_cache
参考https://leetcode.cn/problems/cat-and-mouse-ii/solution/python-ji-xiao-ji-da-bo-yi-by-himymben-ukbk/
def canMouseWin(grid, catJump, mouseJump):""":type grid: List[str]:type catJump: int:type mouseJump: int:rtype: bool"""move = [(0,1),(0,-1),(-1,0),(1,0)]n,m = len(grid),len(grid[0])for i in range(n):for j in range(m):if grid[i][j]=="C":cat = (i,j)elif grid[i][j] =="F":food = (i,j)elif grid[i][j] == "M":mouse = (i,j)@lru_cache(None)def dfs(mloc,cloc,i):if mloc==cloc or cloc==food or i>128:return Falseif mloc == food:return Truepos,jump = mloc,mouseJumpcat_turn = Falseif i%2:pos,jump = cloc,catJumpcat_turn = Truefor dx,dy in move:for step in range(jump+1):nx,ny = pos[0]+dx*step,pos[1]+dy*stepif nx<0 or ny<0 or nx>=n or ny>=m or grid[nx][ny]=="#":breakif not cat_turn and dfs((nx,ny),cloc,i+1):return Trueelif cat_turn and not dfs(mloc,(nx,ny),i+1):return Falsereturn cat_turnreturn dfs(mouse,cat,0)
2/12 1760. 袋子里最少数目的球
二分判断 每个袋子里最多为x时需要的操作次数
如果num<=x 则不需要
x<num<=2x 则需要1次 以此类推
如果此时操作次数op<=maxOperations 则可以将x减小
def minimumSize(nums, maxOperations):""":type nums: List[int]:type maxOperations: int:rtype: int"""l,r = 1,max(nums)ans = 0while l<=r:x = (l+r)//2ops = sum((num-1)//x for num in nums)if ops<=maxOperations:ans = xr = x-1else:l = x+1return ans
2/13 1742. 盒子中小球的最大数量
用map存储每个盒子内的小球数
def countBalls(lowLimit, highLimit):""":type lowLimit: int:type highLimit: int:rtype: int"""def func(x):tag = 0while x>0:tag += x%10x = x//10return tagdic = {}ans = 0for i in range(lowLimit,highLimit+1):tag = func(i)dic[tag] = dic.get(tag,0)+1if dic[tag]>ans:ans = dic[tag]return ans
2/14 1552. 两球之间的磁力
最大化最小值 二分判断mid距离是否合法
check检查距离x合法性
def maxDistance(position, m):""":type position: List[int]:type m: int:rtype: int"""def check(x):pre=position[0]cnt = 1for i in range(1,len(position)):if position[i]-pre>=x:pre = position[i]cnt+=1return cnt>=mposition.sort()l,r=1,position[-1]-position[0]ans = -1while l<=r:mid = (l+r)//2if check(mid):ans = midl=mid+1else:r=mid-1return ans
2/15 1706. 球会落何处
模拟小球运动
小球从上至下运动 行数依次增加 col记录当前小球所在列
如果是1 则向右边移动 col+1
如果是-1 则向左边移动 col-1
此时如果碰到左右两侧 则卡住
或者此时的格子状态与之前不同遇到V型 同样卡住
tag判断小球是否顺利通过
最后记录小球的结果
def findBall(grid):""":type grid: List[List[int]]:rtype: List[int]"""m,n = len(grid),len(grid[0])mem = [[[float('inf'),float('inf')]for _ in range(n)] for _ in range(m)]for i in range(n):if grid[m-1][i]==1:mem[m-1][i][0] = imem[m-1][i][1] = -1if i+1<n:if grid[m-1][i+1]==1:mem[m-1][i][1]=i+1else:mem[m-1][i][1]=imem[m-1][i][0] = -1if i-1>=0:if grid[m-1][i-1]==-1:mem[m-1][i][0] = i-1def check(i,j,loc):ans = float('inf')if mem[i][j][loc]!=float('inf'):return mem[i][j][loc]if grid[i][j]==1:if loc==0:if grid[i+1][j]==1:ans = check(i+1,j,1)else:ans = check(i+1,j,0)else:ans = -1if j+1<n and grid[i][j+1]==1:ans = check(i,j+1,0)else:if loc ==0:ans = -1if j-1>=0 and grid[i][j-1]==-1:ans = check(i,j-1,1)else:if grid[i+1][j]==1:ans = check(i+1,j,1)else:ans = check(i+1,j,0)mem[i][j][loc]=ansreturn ansret = []for j in range(n):loc = 0 if grid[0][j]==-1 else 1ret.append(check(0,j,loc))return retdef findBall2(grid):""":type grid: List[List[int]]:rtype: List[int]"""m,n = len(grid),len(grid[0])ans = [-1]*nfor j in range(n):col = jtag = Truefor i in range(m):mv = grid[i][col]col +=mvif col<0 or col>=n or grid[i][col]!=mv:tag = Falsebreakif tag:ans[j]=colreturn ans
2/16 1299. 将每个元素替换为右侧最大元素
从后往前遍历 记录当前遇到最大的值
def replaceElements(arr):""":type arr: List[int]:rtype: List[int]"""cur=-1for i in range(len(arr)-1,-1,-1):tmp=curcur=max(cur,arr[i])arr[i]=tmpreturn arr
相关文章:
LeetCode 每日一题 2025/2/10-2025/2/16
记录了初步解题思路 以及本地实现代码;并不一定为最优 也希望大家能一起探讨 一起进步 目录 2/10 913. 猫和老鼠2/11 1728. 猫和老鼠 II2/12 1760. 袋子里最少数目的球2/13 1742. 盒子中小球的最大数量2/14 1552. 两球之间的磁力2/15 1706. 球会落何处2/16 1299. 将…...
使用 Shiro 和 JPA 结合 MySQL 实现一个简易权限管理系统
1. 项目设置 首先,确保你的项目已经配置好 Maven 或 Gradle 依赖管理工具,并添加以下依赖: Maven 依赖 <dependencies><!-- Shiro 核心库 --><dependency><groupId>org.apache.shiro</groupId><artifactI…...
DeepSeek与医院电子病历的深度融合路径:本地化和上云差异化分析
一、引言 1.1 研究背景与意义 在医疗信息化快速发展的当下,电子病历系统已成为医院信息管理的核心构成。电子病历(EMR)系统,是指医务人员在医疗活动过程中,使用医疗机构信息系统生成的文字、符号、图标、图形、数据、影像等数字化信息,并能实现存储、管理、传输和重现的…...
设计模式:代理模式
代理模式是很常见的设计模式,即使没有专门学习过这种设计模式,在工作中也一定用过这种设计模式。在实际生活中,代理模式也是常见的,比如内阁首辅相对于皇帝,前者是后者的代理,内阁首辅收到奏折时࿰…...
141,【1】buuctf web [SUCTF 2019]EasyWeb
进入靶场 代码审计 <?php // 定义函数get_the_flag,功能是处理文件上传相关操作 function get_the_flag() {// 注释说明:webadmin会每隔20分钟删除用户上传的文件$userdir "upload/tmp_" . md5($_SERVER[REMOTE_ADDR]);// 检查用户目录…...
破解微服务疑难杂症:2025年全解决方案
微服务架构已经成为现代软件开发的主流选择,其优势在于能够将复杂的系统拆分为独立的服务模块,方便开发和维护。然而,在微服务的实施过程中,开发者往往会面临许多挑战,如服务间通信、数据一致性、性能优化和故障处理等…...
Node.js 中的 Event 模块详解
Node.js 中的 Event 模块是实现事件驱动编程的核心模块。它基于观察者模式,允许对象(称为“事件发射器”)发布事件,而其他对象(称为“事件监听器”)可以订阅并响应这些事件。这种模式非常适合处理异步操作和…...
EasyRTC嵌入式WebRTC视频通话SDK支持Web浏览器、Linux、ARM、Android、iOS
随着互联网技术的飞速发展,实时通信(RTC)已经成为现代应用中不可或缺的一部分。无论是视频会议、在线教育、远程医疗,还是社交娱乐,实时通信技术都在其中扮演着重要角色。 然而,WebRTC技术在PC和移动端的支…...
pycharm社区版有个window和arm64版本,到底下载哪一个?还有pycharm官网
首先pycharm官网是这一个。我是在2025年2月16日9:57进入的网站。如果网站还没有更新的话,那么就往下滑一下找到 community Edition,这个就是社区版了免费的。PyCharm:适用于数据科学和 Web 开发的 Python IDE 适用于数据科学和 Web 开发的 Python IDE&am…...
【玩转全栈】----Django模板语法、请求与响应
目录 一、引言 二、模板语法 三、传参 1、视图函数到模板文件 2、模板文件到视图函数 四、引入静态文件 五、请求与响应 ?1、请求 2、响应 六、综合小案例 1、源码展示 2、注意事项以及部分解释 3、展示 一、引言 像之前那个页面,太过简陋,而且一个完整…...
网络安全:挑战、技术与未来发展
📝个人主页🌹:一ge科研小菜鸡-CSDN博客 🌹🌹期待您的关注 🌹🌹 1. 引言 在数字化时代,网络安全(Cybersecurity)已成为全球关注的焦点。随着云计算、大数据、…...
DeepSeek 服务器繁忙的全面解决方案
目录 引文 正文 一、 服务器繁忙的原因分析 二、 解决方案 2.1切换网络 2.2使用网络加速工具 2.3错峰使用DeepSeek 2.4本地部署 2.5调用API 三、官方动态 一、技术研发与产品升级 二、市场合作与商业化进展 三、区域化布局与产业赋能 四、未来规划与社会责任 结语…...
将OpenWrt部署在x86服务器上
正文共:1234 字 40 图,预估阅读时间:2 分钟 如果你问ChatGPT有哪些开源的SD-WAN方案,他会这样答复你: 我们看到,OpenWrt也属于比较知名的开源SD-WAN解决方案。当然,在很久之前,我就发…...
计算机视觉:卷积神经网络(CNN)基本概念(一)
第一章:计算机视觉中图像的基础认知 第二章:计算机视觉:卷积神经网络(CNN)基本概念(一) 第三章:计算机视觉:卷积神经网络(CNN)基本概念(二) 第四章:搭建一个经典的LeNet5神经网络 一、引言 卷积神经网络&…...
企业文件共享中的权限管理与安全风险防范
在企业的日常运营中,文件共享是必不可少的一项工作。然而,文件共享过程中如果权限管理不当,极易引发安全风险,导致企业敏感信息泄露。因此,加强文件共享中的权限管理与安全风险防范,对于保障企业信息安全至…...
使用DeepSeek建立一个智能聊天机器人0.12
为了确保这段代码能够在Windows和Linux系统上都能正常运行,我考虑以下几个方面: 路径分隔符:在Windows和Linux中,文件路径的分隔符不同。Windows使用反斜杠(\),而Linux使用正斜杠(/)。我们可以使用 os.path.join 来处理路径,以确保跨平台兼容性。 消息框:tkinter.…...
国家队出手!DeepSeek上线国家超算互联网平台!
目前,国家超算互联网平台已推出 DeepSeek – R1 模型的 1.5B、7B、8B、14B 版本,后续还会在近期更新 32B、70B 等版本。 DeepSeek太火爆了!在这个春节档,直接成了全民热议的话题。 DeepSeek也毫无悬念地干到了全球增速最快的AI应用。这几天,国内的云计算厂家都在支持Dee…...
Deep seek学习日记1
Deepseek最强大的就是它的深度思考,并且展现了它的思考过程。 五种可使用Deep seek的方式(应该不限于这五种,后续嵌入deepseek的应该更多,多了解一点因为官网容易崩~~): 1.deep seek官网 2.硅基流动silicon…...
乐理笔记(持续更新)
单音与音程 单音:由一个音组成。 音程:由两个音组成,表示两个音之间的音高距离。 如何数音程: 单音程:9 - X,性质相反。例如,9度音程减去某个数,性质会相反。 复音程:…...
【动态路由】系统Web URL资源整合系列(后端技术实现)【nodejs实现】
需求说明 软件功能需求:反向代理功能(描述:apollo、eureka控、apisix、sentinel、普米、kibana、timetask、grafana、hbase、skywalking-ui、pinpoint、cmak界面、kafka-map、nacos、gateway、elasticsearch、 oa-portal 业务应用等多个web资…...
IDEA运行Tomcat出现乱码问题解决汇总
最近正值期末周,有很多同学在写期末Java web作业时,运行tomcat出现乱码问题,经过多次解决与研究,我做了如下整理: 原因: IDEA本身编码与tomcat的编码与Windows编码不同导致,Windows 系统控制台…...
椭圆曲线密码学(ECC)
一、ECC算法概述 椭圆曲线密码学(Elliptic Curve Cryptography)是基于椭圆曲线数学理论的公钥密码系统,由Neal Koblitz和Victor Miller在1985年独立提出。相比RSA,ECC在相同安全强度下密钥更短(256位ECC ≈ 3072位RSA…...
Admin.Net中的消息通信SignalR解释
定义集线器接口 IOnlineUserHub public interface IOnlineUserHub {/// 在线用户列表Task OnlineUserList(OnlineUserList context);/// 强制下线Task ForceOffline(object context);/// 发布站内消息Task PublicNotice(SysNotice context);/// 接收消息Task ReceiveMessage(…...
STM32标准库-DMA直接存储器存取
文章目录 一、DMA1.1简介1.2存储器映像1.3DMA框图1.4DMA基本结构1.5DMA请求1.6数据宽度与对齐1.7数据转运DMA1.8ADC扫描模式DMA 二、数据转运DMA2.1接线图2.2代码2.3相关API 一、DMA 1.1简介 DMA(Direct Memory Access)直接存储器存取 DMA可以提供外设…...
【SQL学习笔记1】增删改查+多表连接全解析(内附SQL免费在线练习工具)
可以使用Sqliteviz这个网站免费编写sql语句,它能够让用户直接在浏览器内练习SQL的语法,不需要安装任何软件。 链接如下: sqliteviz 注意: 在转写SQL语法时,关键字之间有一个特定的顺序,这个顺序会影响到…...
微服务商城-商品微服务
数据表 CREATE TABLE product (id bigint(20) UNSIGNED NOT NULL AUTO_INCREMENT COMMENT 商品id,cateid smallint(6) UNSIGNED NOT NULL DEFAULT 0 COMMENT 类别Id,name varchar(100) NOT NULL DEFAULT COMMENT 商品名称,subtitle varchar(200) NOT NULL DEFAULT COMMENT 商…...
【配置 YOLOX 用于按目录分类的图片数据集】
现在的图标点选越来越多,如何一步解决,采用 YOLOX 目标检测模式则可以轻松解决 要在 YOLOX 中使用按目录分类的图片数据集(每个目录代表一个类别,目录下是该类别的所有图片),你需要进行以下配置步骤&#x…...
06 Deep learning神经网络编程基础 激活函数 --吴恩达
深度学习激活函数详解 一、核心作用 引入非线性:使神经网络可学习复杂模式控制输出范围:如Sigmoid将输出限制在(0,1)梯度传递:影响反向传播的稳定性二、常见类型及数学表达 Sigmoid σ ( x ) = 1 1 +...
浅谈不同二分算法的查找情况
二分算法原理比较简单,但是实际的算法模板却有很多,这一切都源于二分查找问题中的复杂情况和二分算法的边界处理,以下是博主对一些二分算法查找的情况分析。 需要说明的是,以下二分算法都是基于有序序列为升序有序的情况…...
AI病理诊断七剑下天山,医疗未来触手可及
一、病理诊断困局:刀尖上的医学艺术 1.1 金标准背后的隐痛 病理诊断被誉为"诊断的诊断",医生需通过显微镜观察组织切片,在细胞迷宫中捕捉癌变信号。某省病理质控报告显示,基层医院误诊率达12%-15%,专家会诊…...
