티스토리 뷰

boj 11049 : 행렬 곱셈 순서


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


divide&conquer와 메모이제이션을 이용하여 해결하였다.

a[i][1] : i번째 행렬의 row, a[i][2] : j번째 행렬의 col.

위와같이 두면,


1. f(i,j) : i번째 행렬에서 j번째 행렬까지의 최소 곱셈 수

2. f(i,j) = min { f(i,i) + f(i + 1,j) + a[i][1]*a[i+1][1]*a[j][2] , f(i,i+1) + f(i+2,j) + a[i][1]*a[i+2][1] + a[i][1]*a[i+2][1]*a[j][2], ... , f(i,j-1) + f(j,j) + a[i][1]*a[j][1]*a[j][2] }


중복된 연산을 제거하기 위해 f(i,j)를 메모이제이션한다.

'Problem Solving' 카테고리의 다른 글

boj 1036 : 36진수  (0) 2016.09.09
boj 1915 : 가장 큰 정사각형  (0) 2016.09.09
boj 2011 : 암호코드  (0) 2016.09.09
boj 1520 : 내리막 길  (0) 2016.09.04
boj 1935 : 후위표기식2  (0) 2016.09.04
댓글
공지사항
최근에 올라온 글
최근에 달린 댓글
Total
Today
Yesterday
링크
«   2025/03   »
1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31
글 보관함