반응형
01-27 20:45
- Today
- Total
Link
개발하는 고라니
[백준] 11404번 : 플로이드 본문
반응형
기본적인 플로이드-와샬 알고리즘 문제. 플로이드 와샬의 응용이 아니므로 간단하게 풀 수 있다.
static void Floyd(int n){
for(int k=1; k<=n; k++)
for(int i=1; i<=n; i++)
for(int j=1; j<=n; j++)
if(i == j) continue;
else
d[i][j] = Math.min(d[i][j], d[i][k] + d[k][j]);
for(int i=1; i<=n; i++){
for(int j=1; j<=n; j++)
System.out.print(d[i][j] != INF? d[i][j] + " " : 0 + " ");
System.out.println();
}
}
# Code </>
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.Arrays;
import java.util.StringTokenizer;
public class Main {
static final int INF = 1000000000;
static int[][] d = new int[101][101];
static void Floyd(int n){
for(int k=1; k<=n; k++)
for(int i=1; i<=n; i++)
for(int j=1; j<=n; j++)
if(i == j) continue;
else d[i][j] = Math.min(d[i][j], d[i][k] + d[k][j]);
for(int i=1; i<=n; i++){
for(int j=1; j<=n; j++)
System.out.print(d[i][j] != INF? d[i][j] + " " : 0 + " ");
System.out.println();
}
}
public static void main(String[] args) throws IOException {
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
int n = Integer.parseInt(br.readLine());
int m = Integer.parseInt(br.readLine());
for(int i=1; i<=n; i++)
Arrays.fill(d[i], INF);
for(int i=0; i<m; i++){
StringTokenizer st = new StringTokenizer(br.readLine());
int depart = Integer.parseInt(st.nextToken());
int arrive = Integer.parseInt(st.nextToken());
int distance = Integer.parseInt(st.nextToken());
d[depart][arrive] = Math.min(d[depart][arrive], distance);
}
Floyd(n);
}
}
반응형
'Programming > 백준' 카테고리의 다른 글
[백준] 2458번 : 키 순서 (0) | 2021.03.03 |
---|---|
[백준] 14442번 : 벽 부수고 이동하기 2 (0) | 2021.03.02 |
[백준] 1613번 : 역사 (0) | 2021.02.26 |
[백준] 6593번 : 상범 빌딩 (0) | 2021.02.22 |
[백준] 1194번 : 달이 차오른다, 가자 (0) | 2021.02.21 |
Comments