走迷宫算法:从矩阵mat左上角,走到右下角,求最短路径(广度优先搜索方法)

这是一篇关于经典算法题的博客,主要探讨如何使用广度优先搜索(BFS)方法解决从矩阵的左上角到右下角的最短路径问题。
摘要由CSDN通过智能技术生成

经典算法题

走迷宫算法:从矩阵mat左上角,走到右下角,求最短路径(广度优先搜索方法)

import copy
import queue

def maze(mat):
    '''走迷宫算法,从矩阵mat左上角,走到右下角,求最短路径,使用广度优先搜索方法'''
    m = len(mat) #row
    n = len(mat[0]) #col
    label = copy.deepcopy(mat)  # 用来标记是否访问过,以及是否可以访问
    path = [[(-1, -1) for _ in range(n)] for _ in range(m)]  # 保存到达这一点的前一个坐标
    q = queue.Queue()
    q.put((0, 0)) #队列,实现广度优先搜索
    label[0][0] = 1 #如果允许修改原矩阵mat,那么可以直接在mat矩阵上标记,例如标记为2
    while not q
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值