关注
import java.util.ArrayList;import java.util.LinkedList;import java.util.Scanner; public class Main { public static void main(String[] args) { new Main().solve(); } private void solve() {
Scanner scanner = new Scanner(System.in);
int n = 6;
int adj[][] = new int[n][n];
for (int i = 0; i < n; i++) {
String[] strings= scanner.nextLine().split(" ");
for (int j = 0; j < n; j++) {
adj[i][j] =Integer.valueOf(strings[j]);
}
}
Graph graph = new Graph(adj);
graph.bfs(0);
}
static class Graph {
int[][] adj;
int nVerts;
boolean[] visited;
private Graph(int[][] adj) {
this.adj = adj;
this.nVerts = adj.length;
this.visited = new boolean[nVerts];
}
private void bfs(int start) {
int[] dis=new int[nVerts];
for (int i = 0; i < nVerts; i++) {
dis[i]=Integer.MAX_VALUE;
}
visited[start] = true;
LinkedList<Integer> queue = new LinkedList<>();
queue.add(start);
dis[start]=0;
while (!queue.isEmpty()) {
int v = queue.remove();
ArrayList<Integer> vs;
vs =getNextVertex(v);
for (Integer v1:vs){
int distance=adj[v][v1];
if (distance+dis[v]<dis[v1])
dis[v1]=distance+dis[v];
if (!visited[v1]) {
queue.add(v1);
visited[v1] = true;
}
}
}
for (int i = 0; i <nVerts; i++) {
if (i!=0){
System.out.println(dis[i]);
}
}
}
private ArrayList<Integer> getNextVertex(int v) {
ArrayList<Integer> adjVs = new ArrayList<>();
for (int i = 0; i < adj.length; i++) {
if (i!=v&&adj[v][i] != -1)
adjVs.add(i);
}
return adjVs;
}
}}
查看原帖
点赞 1
相关推荐
点赞 评论 收藏
分享

点赞 评论 收藏
分享
点赞 评论 收藏
分享
牛客热帖
更多
正在热议
更多
# 你认为小厂实习有用吗? #
13461次浏览 186人参与
# 面试官是我前女友 #
106861次浏览 731人参与
# 实习生的蛐蛐区 #
39459次浏览 329人参与
# 当你面对裁员会如何? #
275899次浏览 2438人参与
# 计算机有哪些岗位值得去? #
12695次浏览 132人参与
# lastday知无不言 #
56825次浏览 460人参与
# 在职场上,你最讨厌什么样的同事 #
14403次浏览 150人参与
# 推荐一首陪你工作的歌吧 #
13996次浏览 97人参与
# 说说你知道的学历厂 #
27792次浏览 177人参与
# 你找工作的时候用AI吗? #
14652次浏览 192人参与
# 下班后的时间你怎么安排 #
7248次浏览 111人参与
# 哪一瞬间觉得自己长大了 #
7170次浏览 164人参与
# 携程求职进展汇总 #
559379次浏览 4258人参与
# 面试尴尬现场 #
23282次浏览 163人参与
# 工作后会跟朋友渐行渐远吗 #
29999次浏览 216人参与
# 中核求职进展汇总 #
20106次浏览 152人参与
# 社会教会你的第一课 #
28989次浏览 392人参与
# 多益网络工作体验 #
49591次浏览 280人参与
# 虾皮求职进展汇总 #
244142次浏览 1797人参与
# 神州信息工作体验 #
15968次浏览 75人参与