【leetcode-Python】-BFS-815. Bus Routes

题目链接

https://leetcode.com/problems/bus-routes/

题目描述

给定二维数组routes表示一些公交线路,routes[i]表示第i个公交的公交线路,该公交会在这条线路上接连循环行驶。如果routes[0] = [1,5,7],表示索引为0的公交车会一直按照 1->5->7->1->5->7->1->… 的车站路线行驶。假设我们从 source车站开始(刚开始不在公交车上),要乘坐公交车去target车站。求出最少乘坐的公交车数量。返回 -1 表示不可能到达target车站。

1 <= routes.length <= 500.

1 <= routes[i].length <= 10^5.

0 <= routes[i][j] < 10 ^ 6.

示例

输入:routes = [[1,2,7],[3,6,7]],source = 1,target = 6
输出:2

最优策略是先乘坐第一辆公交车到达车站 7, 然后换乘第二辆公交车到车站 6。

解题思路·BFS

BFS(广度优先搜索)是图搜索算法的一种。常用于解决连通域分解、最短路径(在一幅图中找从start到target的最短距离)等问题。这道题求最少乘坐的公交数类似求最短路径,因此可以考虑利用BFS算法求解。 

给出的routes确定了公交可以到达哪些车站,我们还需要知道在某个车站可

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值