Problem
Concept & Idea
가장 중요한 Concept은 DP[i][j]가 I부터 J까지의 최소 행렬 곱셉 횟수를 메모해놓는 배열이라는 점이다.
간단히 배열값을 바꿔가면서 순차적으로 검색하는 풀이는, 뒤쪽 배열들을 우선적으로 묶었을 때를 고려하지 못한다.
첫번 째 컨셉을 고려해서 문제를 풀기 시작해보자.
최종적으로 구하게되는 값은 DP[1][N]이다.
이 값을 출력하기 이전에, 계산될 과정은 DP[1][N] = DP[1][k] + DP[k+1][n] + map[1][0]map[k][1]map[n][1]; 일것이다.
해당 사진처럼 인덱스를 하나하나 써가며, 풀이를 하면 필요한 작업만 연산할 수 있고, 생각의 정리를 더 잘 할 수 있게 된다.
이런 식으로 연습을 하도록 하자!
Code
Fealing
3일정도 이 문제로 고민했던 것 같다.
순차적으로 인덱스값을 바꿔가며, 풀었을 때는 간단한 값은 맞을 수 있었지만 생각지못했던 케이스가 있었다.
그 경우, ((AB)C)D 이런 경우는 가능하지만 (AB)(CD), A((BC)*D) 이런 경우는 고려하지 못한 풀이였다.
다이나믹 프로그래밍을 어떻게 사용해야할지, 이 풀이를 좀 더 기억해야겠다.
Check out this code in Victoria’s Gist. Please Comment my code in this link.