# 描述 # 定义一个二维数组 N*M ,如 5 × 5 数组下所示: # int maze[5][5] = { # 0, 1, 0, 0, 0, # 0, 1, 1, 1, 0, # 0, 0, 0, 0, 0, # 0, 1, 1, 1, 0, # 0, 0, 0, 1, 0,}; # 它表示一个迷宫,其中的1表示墙壁,0表示可以走的路,只能横着走或竖着走,不能斜着走,要求编程序找出从左上角到右下角的路线。入口点为[0,0],既第一格是可以走的路。 # 数据范围: 2≤n,m≤10 , 输入的内容只包含 0≤val≤1 # 输入描述: # 输入两个整数,分别表示二维数组的行数,列数。再输入相应的数组,其中的1表示墙壁,0表示可以走的路。数据保证有唯一解,不考虑有多解的情况,即迷宫只有一条通道。 # 输出描述: # 左上角到右下角的最短路径,格式如样例所示。 # 示例1 # 输入: # 5 5 # 0 1 0 0 0 # 0 1 1 1 0 # 0 0 0 0 0 # 0 1 1 1 0 # 0 0 0 1 0 # 输出: # (0,0) # (1,0) # (2,0) # (2,1) # (2,2) # (2,3) # (2,4) # (3,4) # (4,4) def func(i, j, pos=[(0, 0)]): # 方法1 if i == m - 1 and j == n - 1: for p in pos: print(p) return 1 if j + 1 < n and a[i][j + 1] == 0: # 向右 if (i, j + 1) not in pos: func(i, j + 1, pos + [(i, j + 1)]) if j - 1 > 0 and a[i][j - 1] == 0: # 向左 if (i, j - 1) not in pos: func(i, j - 1, pos + [(i, j - 1)]) if i + 1 < m and a[i + 1][j] == 0: # 向下 if (i + 1, j) not in pos: func(i + 1, j, pos + [(i + 1, j)]) if i - 1 > 0 and a[i - 1][j] == 0: # 向上 if (i - 1, j) not in pos: func(i - 1, j, pos + [(i - 1, j)]) def dfs(i, j): # 方法2 # 用dx和dy分别来表示:向左, 向右, 向上, 向下 dx = [0, 0, -1, 1] dy = [-1, 1, 0, 0] if i == m - 1 and j == n - 1: for pos in route: print('(' + str(pos[0]) + ',' + str(pos[1]) + ')') return for k in range(4): x = i + dx[k] y = j + dy[k] if 0 <= x < m and 0 <= y < n and map1[x][y] == 0: map1[x][y] = 1 route.append((x, y)) dfs(x, y) # 如果我们无法到达指定终点,则需要沿原路返回,再把标记过的路去掉:map[x][y]=0,route.pop(), # 直到到达当初的分岔路口,进入下一次选择。 map1[x][y] = 0 route.pop() else: return if __name__ == '__main__': m = 5 n = 5 a = [[0, 0, 0, 0, 1], [0, 1, 1, 0, 0], [0, 1, 0, 0, 1], [0, 0, 1, 0, 0], [0, 1, 0, 1, 0]] func(0, 0) map1 = a.copy() route = [(0, 0)] map1[0][0] = 1 dfs(0, 0)
03-15
891
11-09
237
08-19
1万+