题解 | 迷宫问题

迷宫问题

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

import sys

n = m = 0
index = 0
map = []
flag = []
for line in sys.stdin:
    a = line.split("\n")[0]
    if index == 0:
        aa = a.split(" ")
        n = int(aa[0])
        m = int(aa[1])
    else:
        map.append([int(_) for _ in a.split(" ")])
        flag.append([0 for _ in a.split(" ")])
    index += 1
#print(map)
#print(flag)

def dfs(x,y,history):
    #print(history)
    if not flag[x][y]:
        #history.append((x,y))
        flag[x][y]=1
    if x == len(map)-1 and y == len(map[0])-1:
        history.append((x,y))
        return
    if x + 1 <= len(map)-1 and not flag[x+1][y] and not map[x+1][y]:
        history.append((x,y))
        return dfs(x+1,y,history)
    elif x - 1 >= 0 and not flag[x-1][y] and not map[x-1][y]:
        history.append((x,y))
        return dfs(x-1,y,history)
    elif y + 1 <= len(map[0])-1 and not flag[x][y+1] and not map[x][y+1]:
        history.append((x,y))
        return dfs(x,y+1,history)
    elif y - 1 >= 0 and not flag[x][y-1] and not map[x][y-1]:
        history.append((x,y))
        return dfs(x,y-1,history)
    else:
        # 无路可走,开始回退上一个位置,history[-1]
        h = history.pop()
        #print(h)
        return dfs(h[0],h[1],history)
    

history = []
dfs(0,0,history)
for _ in history:
    print("(%s,%s)" % _)

找到能走的路径用dfs最快

如果是找最短那么就是bfs

dfs 就是无脑递归往下走,然后记录history 和flag 表示来时的路和已经走过的路,然后map 为 1 的是墙不能走

走过的路不能走

无路可走了 return history.pop() 再记录下已经走过这里了,那么最终只会剩下一条路,如果多条也是遇到第一条就结束.

bfs 则是把能走的都走一遍,然后把下次要走的加到队列中,遇到了结果了那么就记录下长度

也就是队列里面存的是三元组(x,y,已经走过的长度)

这样就比较方便了

全部评论

相关推荐

05-11 11:48
河南大学 Java
程序员牛肉:我是26届的双非。目前有两段实习经历,大三上去的美团,现在来字节了,做的是国际电商的营销业务。希望我的经历对你有用。 1.好好做你的CSDN,最好是直接转微信公众号。因为这本质上是一个很好的展示自己技术热情的证据。我当时也是烂大街项目(网盘+鱼皮的一个项目)+零实习去面试美团,但是当时我的CSDN阅读量超百万,微信公众号阅读量40万。面试的时候面试官就告诉我说觉得我对技术挺有激情的。可以看看我主页的美团面试面经。 因此花点时间好好做这个知识分享,最好是单拉出来搞一个板块。各大公司都极其看中知识落地的能力。 可以看看我的简历对于博客的描述。这个帖子里面有:https://www.nowcoder.com/discuss/745348200596324352?sourceSSR=users 2.实习经历有一些东西删除了,目前看来你的产出其实很少。有些内容其实很扯淡,最好不要保留。有一些点你可能觉得很牛逼,但是面试官眼里是减分的。 你还能负责数据库表的设计?这个公司得垃圾成啥样子,才能让一个实习生介入数据库表的设计,不要写这种东西。 一个公司的财务审批系统应该是很稳定的吧?为什么你去了才有RBAC权限设计?那这个公司之前是怎么处理权限分离的?这些东西看着都有点扯淡了。 还有就是使用Redis实现轻量级的消息队列?那为什么这一块不使用专业的MQ呢?为什么要使用redis,这些一定要清楚, 就目前看来,其实你的这个实习技术还不错。不要太焦虑。就是有一些内容有点虚了。可以考虑从PR中再投一点产出
点赞 评论 收藏
分享
认真搞学习:28小登的建议,投算法岗不要写什么物理竞赛,互联网+,多写点项目,用什么算法做了什么。还有本科算法是不可能的开发你这个也没有项目啊
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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