D8Q1马走日

题目来源:b站蓝桥杯Python省赛集训p8

题目

给定棋盘大小m,n和马的初始位置a,b。要求马只能和象棋一样走日字。求出马走过棋盘所有格子的总路线数。

实例:m=5,n=4,a=0,b=0,

正确结果:32

思路:马走日一共有八种方向,所以定义方向数组:

way=[[2,1],[1,2],[-2,1],[-1,2],[-2,-1],[-1,-2],[2,-1],[1,-2]]

当需要移动的时候直接可以调用。

再定义棋盘矩阵

lst=[ [0]*n for x in range(m)]

先将初始位置标记为1,含义为已经过该格子,

再定义递归函数move(x,y,step),xy为移动的格子,step是步数,当步数到达m*n时,说明所有格子均已被遍历,可记一条路径——计数器cnt加1,并返回上一层。

在函数中需要循环8次,向八个方向遍历,每次写出一个方向的下一个格子,判断是否在棋盘内和是否未经过,若是,则马移动到那个位置,步数加一,进入下层递归。

当所有情况被遍历,输出计数器结果即为最终结果。

代码

m=5#hang
n=4#lie
lst=[ [0]*n for x in range(m)]
way=[[2,1],[1,2],[-2,1],[-1,2],[-2,-1],[-1,-2],[2,-1],[1,-2]]
cnt=0

def move(x,y,step):
    global cnt
    if step==m*n:
        cnt+=1
        return

    for i in range(len(way)):
        ntx=way[i][0]+x
        nty=way[i][1]+y

        if ntx >= 0 and ntx <= m - 1 and nty >= 0 and nty <= n - 1 and lst[ntx][nty] == 0:
            lst[ntx][nty] = 1
            move(ntx,nty,step+1)
            lst[ntx][nty] = 0

x1=0#初始位置
y1=0
lst[x1][y1]=1
move(x1,y1,1)
print(cnt)

知识点

1. 定义非空二维列表lst=[ [0]*n for x in range(m)]

2. 函数不一定要返回值

3.cnt在函数中使用时需要声明全局变量

  • 9
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值