PythonTip--一马当先--bfs

本文介绍了一个使用Python实现的算法来解决经典的“马走日”问题。该问题要求在一个n*m的网格棋盘上,计算马从左下角移动到右上角所需的最少步数。通过使用广度优先搜索(BFS),文章详细展示了如何定义移动方向,并逐步探索所有可能的路径。

刚学python,小试牛刀

一马当先 
讨论此题 | 解题报告 
顶(39) (AC/Submit)Ratio(477|1829)26.08% 踩(1)

描述:
下过象棋的人都知道,马只能走'日'字形(包括旋转90°的日),现在想象一下,给你一个n行m列网格棋盘,
棋盘的左下角有一匹马,请你计算至少需要几步可以将它移动到棋盘的右上角,若无法走到,则输出-1.
如n=1,m=2,则至少需要1步;若n=1,m=3,则输出-1。

'''
python的二维数组
'''
dx = [1,2,2,1,-1,-2,-2,-1]
dy = [-2,-1,1,2,2,1,-1,-2]
def bfs(n,m):
    vis = [ ([0]*(m+1))  for i in range(n+1)]
    q = [(0,0,0)]
    vis[0][0] = 1
    setp = 0xFFFFFFF
    while q:
        temp = q.pop(0)
        if temp[0] == n and temp[1] == m:
            if temp[2] < setp:
                setp = temp[2]
        for x,y in zip(dx,dy):
            curx = temp[0] + x
            cury = temp[1] + y
            if curx>n or cury>m or curx<0 or cury<0 or vis[curx][cury]:
                continue
            vis[curx][cury] = 1
            curstep = temp[2] + 1
            q.append((curx,cury,curstep))
    return -1 if setp == 0xFFFFFFF else setp

print(bfs(n,m))

 

转载于:https://www.cnblogs.com/evidd/p/7210693.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值