题解 | 迷宫问题

迷宫问题

https://www.nowcoder.com/practice/cf24906056f4488c9ddb132f317e03bc

m, n = map(int, input().split())

maze = [[0] * n for _ in range(m)]
for i in range(m):
    maze[i] = list(map(int, input().split()))

res = []


def ahead(i, j, pos=[(0, 0)]):
    #四个方向试探
    if j + 1 < n and maze[i][j + 1] == 0:
        if (i, j + 1) not in pos:
            ahead(i, j + 1, pos + [(i, j + 1)])
    if j - 1 >= 0 and maze[i][j - 1] == 0:
        if (i, j - 1) not in pos:
            ahead(i, j - 1, pos + [(i, j - 1)])
    if i + 1 < m and maze[i + 1][j] == 0:
        if (i + 1, j) not in pos:
            ahead(i + 1, j, pos + [(i + 1, j)])
    if i - 1 >= 0 and maze[i - 1][j] == 0:
        if (i - 1, j) not in pos:
            ahead(i - 1, j, pos + [(i - 1, j)])
    #找到目标点,将这一分pos拷贝输出打印
    if (i, j) == (m - 1, n - 1):
        for p in pos:
            print("(" + str(p[0]) + "," + str(p[1]) + ")")


ahead(0, 0)

全部评论

相关推荐

05-25 10:45
门头沟学院 Java
Frank_zhan...:没实习一个项目肯定不够,可以再做一个轮子,技术栈再补一个mq,微服务,整体再换个简历模板,暑期尽量再找一个日常实习
无实习如何秋招上岸
点赞 评论 收藏
分享
半解316:内容充实,细节需要修改一下。 1,整体压缩为一页。所有内容顶格。 2,项目描述删除,直接写个人工作量 修改完之后还需要建议,可以私聊
点赞 评论 收藏
分享
不愿透露姓名的神秘牛友
07-07 13:46
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务