240812 플로이드

Jongleee·2024년 8월 12일
0

TIL

목록 보기
649/786
private static final int MAX_DISTANCE = 60000000;

public static void main(String[] args) throws IOException {
	BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
	BufferedWriter bw = new BufferedWriter(new OutputStreamWriter(System.out));
	StringTokenizer st;

	int cityCount = Integer.parseInt(br.readLine());
	int busCount = Integer.parseInt(br.readLine());

	int[][] distances = new int[cityCount + 1][cityCount + 1];

	for (int i = 1; i <= cityCount; i++) {
		Arrays.fill(distances[i], MAX_DISTANCE);
		distances[i][i] = 0;
	}

	for (int i = 0; i < busCount; i++) {
		st = new StringTokenizer(br.readLine(), " ");
		int from = Integer.parseInt(st.nextToken());
		int to = Integer.parseInt(st.nextToken());
		int travelCost = Integer.parseInt(st.nextToken());

		distances[from][to] = Math.min(distances[from][to], travelCost);
	}

	for (int via = 1; via <= cityCount; via++) {
		for (int from = 1; from <= cityCount; from++) {
			for (int to = 1; to <= cityCount; to++) {
				distances[from][to] = Math.min(distances[from][to],
						distances[from][via] + distances[via][to]);
			}
		}
	}

	for (int i = 1; i <= cityCount; i++) {
		for (int j = 1; j <= cityCount; j++) {
			bw.write((distances[i][j] < MAX_DISTANCE ? distances[i][j] : 0) + " ");
		}
		bw.write("\n");
	}

	bw.flush();
	bw.close();
	br.close();
}

출처:https://www.acmicpc.net/problem/11404

0개의 댓글