对于在棋盘上获得最多金币数的问题,金币在棋盘上的行进有一定规则,在遵守规则的条件下,求能够获得的最多金币数。
假设一个mxn的棋盘grig上,每个位置放置着一定数量的grid[i][j]的金币,如果没有金币,则为0,金币在棋盘上按照如下规则进行移动:
1.当到达某一个位置会收集该位置的所有金币,此位置金币数置为0。
2.在棋盘上的每个位置可以向上下左右4个方位移动。
3.出发点可以是棋盘上的任意位置。
4.棋盘上金币数量为0的位置是不可进入的。
由于棋盘上的任意一点均可作为起点,那么选择哪一点作为起点才能获得最多的金币,这就需要遍历棋盘上的每个位置点,尝试以每一个位置点为起点求所能获得的最多金币数,选择获得金币最多点作为起点即可。由此可见,利用双层循环遍历棋盘使不可避免的过程,在主调函数中完成遍历操作。接下来就可以考虑遍历每个点的时候具体执行什么操作,如果当前输入的坐标点i和j已经超过合理范围或者当前位置点为0不可访问,返回0即可,代表着当前位置点向下延伸所能获得的最大金币数为0,返回给上层即可。
当我们访问输入的位置点的时候,需要考虑下一步向上下左右4个方位中的那个方位走才能获得最多金币,那么就需要知道分别从上下左右方位出发所能获得的金币各是多少,选择获得金币最多的那个方位即可,因此,需要对4个方位进行遍历,遍历到每个方位的时候再递归调用函数,从而能够得到获得的最多金币数,与当前位置的金币数相加上即可,也就是从当前位置出发所能获得的最多金币数,返回即可。这里需要特别注意,在出来当前节点的时候,由于需要遍历该节点上下左右4个方位,在计算当前节点4个方位的最大金币数的时候,为了避免重复访问到当前节点,在遍历4个方位之前,将此节点的的金币数置为0即可,然后在遍历完4个方位之后再将其恢复节点值。
以第一个例子中的一个位置[2,1]为例,也就是金币数为5的位置,首先遍历此为止的上下左右,其中左右返回的是0.只有上位置需要继续向下深入:
遍历金币数为4的节点的4个方位,上方向返回的是2,左返回1,右返回3,从中选取最多金币数为3,节点4返回3+4=7,给节点5,因此节点5的下一步只有走上方,才能获得7个金币,最终返回结果是12
使用python实现的代码如下:
class Solution:
def func(self, grid):
re=0
self.directions=[[1,0],[-1,0],[0,1],[0,-1]]
for i in range(len(grid)):
for j in range(len(grid[0])):
if grid[i][j]!=0:
re=max(re,self.dfs(i,j,grid))
return re
def dfs(self,i,j,grid):
if len(grid)<=i or i<0 or len(grid[0])<=j or j<0 or grid[i][j]==0:
return 0
current_value=grid[i][j]
grid[i][j]=0
max_=0
for direction in self.directions:
re=max(max_,self.dfs(i+direction[0],j+direction[1],grid))
grid[i][j]=current_value
return max_+current_value
以上就是“python使用回溯算法解决获得最多金币问题”的全部内容,希望对你有所帮助。
关于Python技术储备
学好 Python 不论是就业还是做副业赚钱都不错,但要学会 Python 还是要有一个学习规划。最后大家分享一份全套的 Python 学习资料,给那些想学习 Python 的小伙伴们一点帮助!
一、Python所有方向的学习路线
Python所有方向的技术点做的整理,形成各个领域的知识点汇总,它的用处就在于,你可以按照上面的知识点去找对应的学习资源,保证自己学得较为全面。
二、Python必备开发工具
三、Python视频合集
观看零基础学习视频,看视频学习是最快捷也是最有效果的方式,跟着视频中老师的思路,从基础到深入,还是很容易入门的。
四、实战案例
光学理论是没用的,要学会跟着一起敲,要动手实操,才能将自己的所学运用到实际当中去,这时候可以搞点实战案例来学习。
五、Python练习题
检查学习结果。
六、面试资料
我们学习Python必然是为了找到高薪的工作,下面这些面试题是来自阿里、腾讯、字节等一线互联网大厂最新的面试资料,并且有阿里大佬给出了权威的解答,刷完这一套面试资料相信大家都能找到满意的工作。
最后祝大家天天进步!!
上面这份完整版的Python全套学习资料已经上传至CSDN官方,朋友如果需要可以直接微信扫描下方CSDN官方认证二维码免费领取【保证100%免费】。