240116 최적의 행렬 곱셈

Jongleee·2024년 1월 16일
0

TIL

목록 보기
470/737
public int solution(int[][] matrixSizes) {
	int numMatrices = matrixSizes.length;
	int[][] dp = new int[numMatrices][numMatrices];

	for (int i = 0; i < numMatrices; i++) {
		for (int j = 0; j < numMatrices; j++) {
			dp[i][j] = Integer.MAX_VALUE;
		}
	}

	for (int len = 0; len < numMatrices; len++) {
		for (int start = 0; start < numMatrices - len; start++) {
			int end = start + len;
			if (start == end) {
				dp[start][end] = 0;
			} else {
				for (int k = start; k < end; k++) {
					dp[start][end] = Math.min(dp[start][end], dp[start][k] + dp[k + 1][end] +
							matrixSizes[start][0] * matrixSizes[k][1] * matrixSizes[end][1]);
				}
			}
		}
	}

	return dp[0][numMatrices - 1];
}

출처:https://school.programmers.co.kr/learn/courses/30/lessons/12942

0개의 댓글