题目来源: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在函数中使用时需要声明全局变量