ProgramSoliving

백준 : 17182 우주 탐사선

하이후에호 2021. 4. 13. 23:48
반응형

www.acmicpc.net/problem/17182

 

17182번: 우주 탐사선

우주 탐사선 ana호는 어떤 행성계를 탐사하기 위해 발사된다. 모든 행성을 탐사하는데 걸리는 최소 시간을 계산하려 한다. 입력으로는 ana호가 탐색할 행성의 개수와 ana호가 발사되는 행성의 위

www.acmicpc.net

1. 플로이드 와샬로 각각의 에지에서 다른 에지로가는 최소비용 구하기

2. flag라는 현재 방문한 상태자체를 int형으로해서 보낸다 (N<10 이라 가능)

3. DFS로 최소값 구하기, 이때 구해지 해답보다 현재답이 클경우 가지치기를 이용해서 구한다.

package boj;

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.StringTokenizer;

public class boj17182 {
	static int N, K;

	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());
		K = Integer.parseInt(st.nextToken());
		disit = new int[N][N];
		for (int i = 0; i < N; i++) {
			st = new StringTokenizer(br.readLine());
			for (int j = 0; j < N; j++) {
				disit[i][j] = Integer.parseInt(st.nextToken());
			}
		}

		System.out.println(solve());
	}

	static int disit[][];
	static int dp[][];
	static int ans;

	private static int solve() {
		init();
		DFS(1 << K, 0, 1, K);
		return ans;
	}

	private static void DFS(int flag, int distance, int cnt, int cur) {
		if (cnt == N) {
			ans = Math.min(ans, distance);
			return;
		}

		if (ans <= distance)
			return;

		for (int i = 0; i < N; i++) {
			if ((flag & (1 << i)) == (1 << i))
				continue;
			DFS(flag | (1 << i), distance + disit[cur][i], cnt + 1, i);

		}

	}

	static final int INF = 987654321;

	private static void init() {
		ans = INF;

		for (int n = 0; n < N; n++) {
			for (int i = 0; i < N; i++) {
				if (i == n) {
					continue;
				}
				for (int j = 0; j < N; j++) {
					// 자기자신 가는 경로는 0
					if (j == i || j == n)
						continue;
					disit[i][j] = Math.min(disit[i][j], disit[i][n] + disit[n][j]);
				}
			}
		}
	}
}
반응형