首页 技术 正文
技术 2022年11月8日
0 收藏 592 点赞 2,047 浏览 1623 个字

815. 公交路线

我们有一系列公交路线。每一条路线 routes[i] 上都有一辆公交车在上面循环行驶。例如,有一条路线 routes[0] = [1, 5, 7],表示第一辆 (下标为0) 公交车会一直按照 1->5->7->1->5->7->1->… 的车站路线行驶。

假设我们从 S 车站开始(初始时不在公交车上),要去往 T 站。 期间仅可乘坐公交车,求出最少乘坐的公交车数量。返回 -1 表示不可能到达终点车站。

示例:

输入:

routes = [[1, 2, 7], [3, 6, 7]]

S = 1

T = 6

输出: 2

解释:

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

说明:

1 <= routes.length <= 500.

1 <= routes[i].length <= 500.

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

import java.awt.Point;
class Solution {
public int numBusesToDestination(int[][] routes, int S, int T) {
if (S == T) {
return 0;
}
int numsOfBus = routes.length;
List<List<Integer>> busGraph = new ArrayList<>();
for (int i = 0; i < numsOfBus; i++) {
Arrays.sort(routes[i]);
busGraph.add(new ArrayList<>());
}
//把有相同站点的车联系起来
for (int i = 0; i < numsOfBus; i++) {
for (int j = i + 1; j < numsOfBus; j++) {
if (intersect(routes[i], routes[j])) {
busGraph.get(i).add(j);
busGraph.get(j).add(i);
}
}
}
Queue<int[]> queue = new LinkedList<>();
List<Integer> seen = new ArrayList<>();
List<Integer> targets = new ArrayList<>();
// 包含起点的加入起始队列,包含目的地的加入目标队列
// seen用来确保
for (int i = 0; i < numsOfBus; i++) {
if (Arrays.binarySearch(routes[i], S) >= 0) {
seen.add(i);
queue.add(new int[]{i, 0});
}
if (Arrays.binarySearch(routes[i], T) >= 0) {
targets.add(i);
}
}
//BFS走起
while (!queue.isEmpty()) { int[] cur = queue.poll();
int busLine = cur[0];
int depth = cur[1];
if (targets.contains(busLine)) {
return depth + 1;
}
List<Integer> neighbors = busGraph.get(busLine);
for (int k = 0; k < neighbors.size(); k++) {
if (!seen.contains(neighbors.get(k))) {
seen.add(neighbors.get(k));
queue.add(new int[]{neighbors.get(k), depth + 1});
}
} }
return -1;
} private boolean intersect(int[] route1, int[] route2) {
int len1 = route1.length;
int len2 = route2.length;
int i = 0;
int j = 0;
while (i < len1 && j < len2) {
if (route1[i] == route2[j]) {
return true;
}
if (route1[i] > route2[j]) {
j++;
}
else
{
i++;
}
}
return false;
}
}
相关推荐
python开发_常用的python模块及安装方法
adodb:我们领导推荐的数据库连接组件bsddb3:BerkeleyDB的连接组件Cheetah-1.0:我比较喜欢这个版本的cheeta…
日期:2022-11-24 点赞:878 阅读:9,487
Educational Codeforces Round 11 C. Hard Process 二分
C. Hard Process题目连接:http://www.codeforces.com/contest/660/problem/CDes…
日期:2022-11-24 点赞:807 阅读:5,903
下载Ubuntn 17.04 内核源代码
zengkefu@server1:/usr/src$ uname -aLinux server1 4.10.0-19-generic #21…
日期:2022-11-24 点赞:569 阅读:6,736
可用Active Desktop Calendar V7.86 注册码序列号
可用Active Desktop Calendar V7.86 注册码序列号Name: www.greendown.cn Code: &nb…
日期:2022-11-24 点赞:733 阅读:6,486
Android调用系统相机、自定义相机、处理大图片
Android调用系统相机和自定义相机实例本博文主要是介绍了android上使用相机进行拍照并显示的两种方式,并且由于涉及到要把拍到的照片显…
日期:2022-11-24 点赞:512 阅读:8,126
Struts的使用
一、Struts2的获取  Struts的官方网站为:http://struts.apache.org/  下载完Struts2的jar包,…
日期:2022-11-24 点赞:671 阅读:5,287