ProgramSoliving

백준 : 1800 인터넷 설치 JAVA

하이후에호 2021. 4. 7. 22:36
반응형

www.acmicpc.net/problem/1800

 

1800번: 인터넷 설치

첫 번째 줄에 N(1 ≤ N ≤ 1,000), 케이블선의 개수 P(1 ≤ P ≤ 10,000), 공짜로 제공하는 케이블선의 개수 K(0 ≤ K < N)이 주어진다. 다음 P개의 줄에는 케이블이 연결하는 두 컴퓨터 번호와 그 가격이 차

www.acmicpc.net

 

문제유형 : 이분탐색, 다잌스트라

 

접근 아이디어 : 다잌스트라에 특정 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;
		}

	}

}
반응형