240819 외판원 순회

Jongleee·2024년 8월 19일
0

TIL

목록 보기
655/786
private static final int INF = 15000000;

public static void main(String[] args) throws IOException {
	BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
	int n = Integer.parseInt(br.readLine());

	int[][] matrix = new int[n][n];
	for (int i = 0; i < n; i++) {
		StringTokenizer st = new StringTokenizer(br.readLine());
		for (int j = 0; j < n; j++) {
			int value = Integer.parseInt(st.nextToken());
			matrix[i][j] = (i != j && value == 0) ? INF : value;
		}
	}

	int[][] dp = new int[n][1 << (n - 1)];
	for (int i = 1; i < n; i++) {
		dp[i][0] = matrix[i][0];
	}

	int minDistance = INF;
	int fullBitmask = (1 << (n - 1)) - 1;
	for (int i = 1; i < n; i++) {
		int bitmask = fullBitmask & ~(1 << (i - 1));
		minDistance = Math.min(minDistance, tsp(dp, matrix, i, bitmask, n) + matrix[0][i]);
	}

	System.out.println(minDistance);
	br.close();
}

private static int tsp(int[][] dp, int[][] matrix, int current, int bitmask, int n) {
	if (dp[current][bitmask] != 0) {
		return dp[current][bitmask];
	}

	int minDistance = INF;
	for (int i = 1; i < n; i++) {
		if ((bitmask & (1 << (i - 1))) == 0) continue;

		int nextBitmask = bitmask & ~(1 << (i - 1));
		dp[i][nextBitmask] = tsp(dp, matrix, i, nextBitmask, n);
		minDistance = Math.min(minDistance, matrix[current][i] + dp[i][nextBitmask]);
	}

	dp[current][bitmask] = minDistance;
	return minDistance;
}

출처:https://www.acmicpc.net/problem/2098

0개의 댓글