python使用回溯算法解决获得最多金币问题

本文介绍了一种使用Python实现的回溯算法解决在给定棋盘上,从任意起始点出发收集金币并最大化累积金币数的问题。算法通过双层循环遍历棋盘,递归计算每个位置的最优路径。
摘要由CSDN通过智能技术生成

对于在棋盘上获得最多金币数的问题,金币在棋盘上的行进有一定规则,在遵守规则的条件下,求能够获得的最多金币数。

假设一个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必备开发工具

img

三、Python视频合集

观看零基础学习视频,看视频学习是最快捷也是最有效果的方式,跟着视频中老师的思路,从基础到深入,还是很容易入门的。

img

四、实战案例

光学理论是没用的,要学会跟着一起敲,要动手实操,才能将自己的所学运用到实际当中去,这时候可以搞点实战案例来学习。

img

五、Python练习题

检查学习结果。

img

六、面试资料

我们学习Python必然是为了找到高薪的工作,下面这些面试题是来自阿里、腾讯、字节等一线互联网大厂最新的面试资料,并且有阿里大佬给出了权威的解答,刷完这一套面试资料相信大家都能找到满意的工作。

img

最后祝大家天天进步!!

上面这份完整版的Python全套学习资料已经上传至CSDN官方,朋友如果需要可以直接微信扫描下方CSDN官方认证二维码免费领取【保证100%免费】。

  • 23
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值