ProgramSoliving
백준 : 1800 인터넷 설치 JAVA
하이후에호
2021. 4. 7. 22:36
반응형
문제유형 : 이분탐색, 다잌스트라
접근 아이디어 : 다잌스트라에 특정 x값 이하로 이을수 있나 탐색
x값 이하면 비용 0 x값 초과시 비용1이라고한다면 x값 초과하는 연결선의 개수를 알게된다.
그 개수가 K이면은 true 이렇게 함수를 만들고 이분탐색 하면된다.
package boj;
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.PriorityQueue;
import java.util.Queue;
import java.util.StringTokenizer;
import boj.B1800.Edge;
public class B1800 {
static class Edge implements Comparable<Edge> {
int v;
int w;
public Edge(int v, int w) {
super();
this.v = v;
this.w = w;
}
@Override
public int compareTo(Edge o) {
return this.w - o.w;
}
}
static int N, P, K;
static ArrayList<Edge>[] edge;
public static void main(String[] args) throws IOException {
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
StringTokenizer st = new StringTokenizer(br.readLine());
N = Integer.parseInt(st.nextToken());
P = Integer.parseInt(st.nextToken());
K = Integer.parseInt(st.nextToken());
edge = new ArrayList[N + 1];
for (int n = 1; n <= N; n++)
edge[n] = new ArrayList<>();
for (int p = 0; p < P; p++) {
st = new StringTokenizer(br.readLine());
int a = Integer.parseInt(st.nextToken());
int b = Integer.parseInt(st.nextToken());
int w = Integer.parseInt(st.nextToken());
edge[a].add(new Edge(b, w));
edge[b].add(new Edge(a, w));
}
// Dickstra
int front = 0, rear = INF;
int ans = -1;
while (front <= rear) {
int mid = (front + rear) / 2;
if (Dickstra(mid)) {
ans = mid;
rear = mid - 1;
} else {
front = mid + 1;
}
}
// print
System.out.println(ans);
}
private static boolean Dickstra(int x) {
// 초기화
inti();
// 시작지점 1번
Queue<Edge> q = new PriorityQueue<Edge>();
q.add(new Edge(1, 0));
// 다잌스트라 탐색
while (!q.isEmpty()) {
Edge cur = q.poll();
for (Edge next : edge[cur.v]) {
int w = next.w <= x ? 0 : 1;
if (dist[next.v] > cur.w + w) {
dist[next.v] = cur.w + w;
q.add(new Edge(next.v, cur.w + w));
}
}
}
return dist[N] <= K;
}
static int dist[];
static final int INF = 987654321;
private static void inti() {
dist = new int[N + 1];
for (int i = 2; i <= N; i++) {
dist[i] = INF;
}
}
}
반응형