题目链接
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确定了公交可以到达哪些车站,我们还需要知道在某个车站可