码迷,mamicode.com
首页 > 其他好文 > 详细

dp-最优矩阵链乘

时间:2019-12-08 01:41:36      阅读:118      评论:0      收藏:0      [点我收藏+]

标签:矩阵链乘   href   math   lin   time   org   设计   tip   顺序   

来自于紫书

题目大意

\(n\)个矩阵组成的序列,设计一种运算顺序把它们依次乘起来,使得总运算量最小。假设第i个矩阵\(A_i\)\(P_{i-1} \times P_i\)的。(\(n<=100\)

例如:假设\(A\)\(B\)\(C\)分别是\(1 \times 50 , 50 \times 20 , 20 \times 5\)

\(A \times (B \times C)\)的运算量为\(1 \times 50 \times 5 + (50 \times 20 \times 5) = 5250\)

\((A \times B) \times C\)的运算量为\((1 \times 50 \times 20) + 1 \times 20 \times 5 = 1100\)

显然后者更优

解法

最后一次乘时整个矩阵序列一定是被分成两半,假设分界点是\(k\)

\(L = A_1 \times A_2 \times ... \times A_k\)\(R = A_{k+1} \times A_{k+1} \times ... \times A_n\)

无论\(L\)\(R\)的内部怎样乘,最后\(L \times R\)的运算量都是不变的

故可以让\(L\)\(R\)按各自最优方案计算,最后再加上\(L \times R\)的运算量即可

所以可以设\(f(i,j)\)表示第\(i\)个矩阵到第\(j\)个矩阵乘起来所需的最少的运算量,转移方程为:

\(f(i,j) = min\{ f(i,k) + f(k+1,j) + P_{i-1} \times P_k \times P_j \} \ ( i <= k < j)\)

边界\(f(i,i) = 0\),因为转移方程中\(k >= i\)\(k < j\),所以\(dp\)的顺序为\(i\)递减,\(j\)递增

模板题:Poj-1651 Multiplication Puzzle

如果没看过矩阵链乘题目的话,估计一时半会还想不出这道题

dp-最优矩阵链乘

标签:矩阵链乘   href   math   lin   time   org   设计   tip   顺序   

原文地址:https://www.cnblogs.com/smsylby/p/12003936.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!