[백준(Baekjoon)][자바(java)] 1005 : ACM Craft / 위상 정렬

728x90

 

https://www.acmicpc.net/problem/1005

 

1005번: ACM Craft

첫째 줄에는 테스트케이스의 개수 T가 주어진다. 각 테스트 케이스는 다음과 같이 주어진다. 첫째 줄에 건물의 개수 N과 건물간의 건설순서 규칙의 총 개수 K이 주어진다. (건물의 번호는 1번부

www.acmicpc.net

 

문제 풀이

 

*  DFS + DP

import java.io.BufferedReader;
import java.io.InputStreamReader;
import java.util.*;

public class Main {
	
	static List<List<Integer>> edge_in;
	static int time[];
	static long dp[];
	
	public static long dfs(int u) {
		if (dp[u] != -1) return dp[u];
		long time_max = 0;
		for (int v : edge_in.get(u))
			time_max = Math.max(time_max, dfs(v));
		time_max += time[u];
		return dp[u] = time_max;
	}

	public static void main(String[] args) throws Exception {
		BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
		StringTokenizer st;
		int t = Integer.parseInt(br.readLine()), n, k, w, u, v, i;
		StringBuilder sb = new StringBuilder();
		while (t-- > 0) {
			st = new StringTokenizer(br.readLine());
			n = Integer.parseInt(st.nextToken());
			k = Integer.parseInt(st.nextToken());
			time = new int[n];
			st = new StringTokenizer(br.readLine());
			for (i = 0; i < n; ++i)
				time[i] = Integer.parseInt(st.nextToken());
			edge_in = new ArrayList<>();
			for (i = 0; i < n; ++i)
				edge_in.add(new ArrayList<>());
			for (i = 0; i < k; ++i) {
				st = new StringTokenizer(br.readLine());
				u = Integer.parseInt(st.nextToken()) - 1;
				v = Integer.parseInt(st.nextToken()) - 1;
				edge_in.get(v).add(u);
			}
			w = Integer.parseInt(br.readLine()) - 1;
			dp = new long[n];
			for (i = 0; i < n; ++i)
				dp[i] = -1;
			sb.append(dfs(w) + "\n");
		}
		br.close();
		System.out.println(sb.toString());
	}
}

 

 

반응형