728x90
반응형
Minimum 다익스트라
- 제목
허들 넘기
- 조건
시간 제한 : 2 초
메모리 제한 : 1024 MB
- 문제
허들 국가대표를 꿈꾸는 연두는 그래프 위에서 허들 넘기를 연습하려고 한다. 연두가 연습할 그래프는 정점이 N개 있고, 간선이 M개 있다. 간선은 방향성이 있어, 1에서 2로 가는 길이 있더라도, 2에서 1로 가는 길은 없을 수도 있다. 간선 위에는 허들이 중간에 놓여 있고, 간선을 지나갈 때는 반드시 허들을 넘어야 한다.
연두는 연습을 T번 할 것이고, 각 연습마다 출발 정점과 도착 정점을 미리 정해놓았다. 연두가 힘들지 않게 연습을 하기 위해, 각 연습마다 출발 정점에서 도착 정점으로 가는 경로 중에서 가장 높이가 높은 허들의 높이가 최소가 되는 것을 찾아보자.
- 입력
첫째 줄에 세 정수 N, M, T가 주어진다. 다음 M개의 줄에 그래프 간선의 정보 u, v, h가 주어지고, u에서 v로 가는 간선이 있고, 높이가 h인 허들이 간선 중간에 놓여 있다는 의미이다. 마지막 T개의 줄에는 연습의 정보 s, e가 한 줄에 하나씩 주어진다. s는 출발 정점, e는 도착 정점을 의미한다.
- 출력
입력으로 주어진 연습 마다 한 줄에 하나씩 출발 정점에서 도착 정점으로 가는 경로 중 가장 높은 허들 높이의 최솟값을 출력한다. 만약 출발 정점에서 도착 정점으로 갈 수 없는 경우 -1을 출력한다.
- 제한
1 ≤ N ≤ 300
1 ≤ M ≤ 25,000
1 ≤ T ≤ 40,000
1 ≤ u, v ≤ N
u ≠ v
1 ≤ h ≤ 1,000,000
1 ≤ s, e ≤ N
s ≠ e
예제 입력1 | 예제 출력1 |
5 6 3 1 2 12 3 2 8 1 3 5 2 5 3 3 4 4 2 4 8 3 4 1 2 5 1 |
4 8 -1 |
import java.io.*;
import java.util.*;
public class Main {
static BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
static StringBuilder sb = new StringBuilder();
static StringTokenizer st;
public static void main(String[] args) throws IOException {
int INF = Integer.MAX_VALUE;
st = new StringTokenizer(br.readLine());
int N = Integer.parseInt(st.nextToken());
int M = Integer.parseInt(st.nextToken());
int T = Integer.parseInt(st.nextToken());
int[][] dist = new int[N][N];
for(int i = 0; i < N; i++){
for(int j = 0; j < N; j++){
dist[i][j] = INF;
}
}
for(int i = 0; i < M; i++){
st = new StringTokenizer(br.readLine());
int u = Integer.parseInt(st.nextToken()) - 1;
int v = Integer.parseInt(st.nextToken()) - 1;
int h = Integer.parseInt(st.nextToken());
dist[u][v] = h;
}
for(int k = 0; k < N; k++){
for(int i = 0; i < N; i++){
if(dist[i][k] == INF) continue;
for(int j = 0; j < N; j++){
if(dist[k][j] == INF) continue;
dist[i][j] = Math.min(dist[i][j], Math.max(dist[i][k], dist[k][j]));
}
}
}
for(int i = 0; i < T; i++){
st = new StringTokenizer(br.readLine());
int s = Integer.parseInt(st.nextToken()) - 1;
int e = Integer.parseInt(st.nextToken()) - 1;
sb.append(dist[s][e] == INF ? -1 : dist[s][e]).append('\n');
}
System.out.print(sb);
}
}
728x90
반응형
'Problem Solving > BaekJoon' 카테고리의 다른 글
[BOJ/백준] 25395 - 커넥티드 카 실험 (0) | 2024.02.28 |
---|---|
[BOJ/백준] 31410 - 제독 작전 (1) | 2024.02.28 |
[BOJ/백준] 1766 - 문제집 (1) | 2024.02.26 |
[BOJ/백준] 31230 - 모비스터디 (0) | 2024.02.26 |
[BOJ/백준] 31434 - 당근 클릭 게임 (0) | 2024.02.25 |