python每日一题【剑指 Offer 13. 机器人的运动范围】
admin
2024-03-02 10:21:28
0

day23-2022.11.18

题目信息来源
作者:Krahets
链接:https://leetcode.cn/leetbook/read/illustration-of-algorithm
来源:力扣(LeetCode)

剑指 Offer 13. 机器人的运动范围

地上有一个m行n列的方格,从坐标 [0,0] 到坐标 [m-1,n-1] 。一个机器人从坐标 [0, 0] 的格子开始移动,它每次可以向左、右、上、下移动一格(不能移动到方格外),也不能进入行坐标和列坐标的数位之和大于k的格子。例如,当k为18时,机器人能够进入方格 [35, 37] ,因为3+5+3+7=18。但它不能进入方格 [35, 38],因为3+5+3+8=19。请问该机器人能够到达多少个格子?
示例 1:

输入:m = 2, n = 3, k = 1
输出:3
示例 2:
输入:m = 3, n = 1, k = 0
输出:1

提示:

  • 1 <= n,m <= 100

  • 0 <= k <= 20

题解:个人版

昨天做了一题,总之能照猫画虎做出来一题

  • 递归参数:行坐标i, 列坐标j

  • 终止条件:超出边界,不符合规则,已经看过的地方。用了一个二维列表来标记,还踩了雷。

  • 递推工作:标记已经选过的列表,搜索下一个单元格,计数

  • 返回值:无。选择了一个全局变量来计数,说实话,我没太想好怎么在递归中计数,这个尝试失败了

相关知识点

行坐标和列坐标的数位之和计算,设行坐标为i,列坐标为j,则计算行坐标数位之和为i//10+i%10,即整除和取余。我这里可能钻了测试题的漏洞,如果出现m,n=100,可能就bug了。

class Solution:def movingCount(self, m: int, n: int, k: int) -> int:# 递归参数:行坐标i, 列坐标j# 终止条件:超出边界,不符合规则# 递推工作:标记已经选过的列表,搜索下一个单元格,计数# 返回值self.m, self.n, self.k = m, n, kself.result = 0self.myset = [[0 for x in range(n)] for x in range(m)]self.move(0, 0)return self.resultdef move(self, i, j):if i>=self.m or j>=self.n:return#if i<0 or i>=self.m or j<0 or j>=self.n:returnif self.myset[i][j]==1:returnif self.myset[i][j]==0:self.myset[i][j] = 1if (i//10+i%10+j//10+j%10)>self.k:returnelse:self.result = self.result + 1# self.move(i-1, j)self.move(i+1, j)# self.move(i, j-1)self.move(i, j+1)return

题解:官方

官方题解知识点重点

  1. 数位增量和公式解释:若xx+1不超过两位数
  • 当 x+1//10=0x+1//10=0x+1//10=0 时,xxx 的个位为9,x+1x+1x+1 的个位为0,比 xxx 小9,x+1x+1x+1 的十位比 xxx 的十位大1,整体就比 xxx 小8
  • 当 x+1//10≠0x+1//10\neq0x+1//10​=0 时,就比 xxx 大1
  1. 理解不可达解:有限制,机器人每次只能走一步。只有之前走过的连通了才可以。
  2. 剪枝:分析可知机器人可通过只往增序列处走就能访问所有可达解。(然后我偷偷注释了我代码里递归的两行,试了一下,确实不影响结果并且提升了速度减少了内存)
  3. 我也尝试用set()来标记走过的点,来剪枝,但是失败了,因为我的语法是set.add([i,j]),看了解析用的是set.add((i,j))
  4. 关于我没法把计数放到递归里的解决方案:解析里用的是+,如果不符合条件的直接会返回 0,所以会没有变化,其他情况都是被1+

but,官方解析里sisj的写法很容易混淆,其实就是 x 和 x+1 的数位之和

广度优先遍历 BFS

以平推的方式向前搜索,通常会利用队列实现。

  • 初始化:将初始点加入队列
  • 迭代终止条件:队列为空
  • 迭代工作:
    • 出队
    • 判断是否跳过
    • 标记
    • 入队

尝试复现官方题解的广度优先遍历

class Solution:def movingCount(self, m: int, n: int, k: int) -> int:# 初始化需要队列遍历存储遍历的列表,需要一个列表存储已经标记过的格子myqueue = [(0, 0, 0, 0)]choosed = set()while myqueue:x, y, sum_x, sum_y = myqueue.pop(0)if x>=m or y>=n or sum_x+sum_y>k or (x,y) in choosed:continuechoosed.add((x, y))myqueue.append((x+1, y, sum_x+1 if (x+1)%10!=0 else sum_x-8, sum_y))myqueue.append((x, y+1, sum_x, sum_y+1 if (y+1)%10!=0 else sum_y-8))return len(choosed)

相关内容

热门资讯

三季度公募基金调查显示:科技成... 7月6日消息,公募基金配置偏好,素来是市场的重要风向标之一。近日,联合天天基金进行了三季度公募基金调...
现货黄金向上触及4200美元,... 7月6日消息,现货黄金向上触及4200美元,日内上涨0.61%。(广角观察)
盯上AI基建“卖铲人”,泡沫说... 卡特彼勒这只“最不像AI股的AI股”被做空,恰恰为AI泡沫争论提供了一个绝佳的观察窗口。文/每日资本...
四川绵竹地震目前未造成人员伤亡... 7月6日消息,据中国地震台网正式测定,5日23时03分、23时20分、23时30分,德阳绵竹市先后发...
伊朗最高领袖任命埃杰伊继续担任... 7月6日消息,据伊朗最高领袖办公室当地时间7月5日消息,伊朗最高领袖穆杰塔巴·哈梅内伊发布任免令,再...
电子布价格连涨,产业链上游高端... 7月6日消息,“现在高端电子布专用喷气织机需求异常火爆。日本丰田织机占据全球90%以上的市场份额。如...
2026年五月廿一:古老民俗与... 随着2026年的脚步渐行渐远,我们迎来了一年中一个特别的日子——农历五月廿一。这一天,在古代被视为‘...
长春市怎么找到合适的经济纠纷律... 这类法律服务的适用场景与市场现状 在日常商业活动和个人资产处置过程中,时常会遇到权责划分不清晰、合同...
永辉前人力总张卫东加入大润发,... 一段时间来,大润发对其组织人事做了一系列调整。有市场人士告诉《商业观察家》,“永辉改革领导小组”组员...
中际旭创接连澄清市场传闻:玻璃... 7月5日晚间,光模块龙头中际旭创(300308)在深交所互动易就两大市场传闻进行澄清。有投资者提问,...