其他分享
首页 > 其他分享> > 动态规划_备忘录法_矩阵链乘问题

动态规划_备忘录法_矩阵链乘问题

作者:互联网

目录

 

问题描述

给定nn个矩阵{A1,A2,A3,...,An}{A1,A2,A3,...,An},其中AiAi为Pi−1×PiPi−1×Pi矩阵,i=1,...,ni=1,...,n,并且AiAi与Ai−1Ai−1是可乘的。由于矩阵乘法满足结合律,所以计算矩阵的链乘可有许多不同的计算次序,两个矩阵Ai×jAi×j与Aj×kAj×k相乘的工作量为i×j×ki×j×k次数乘。
给定向量P=<P0,P1,...,Pn>P=<P0,P1,...,Pn>为nn个矩阵的行数和列数,确定一种乘法次序,使得基本运算“数乘”的总次数最少。

完全加括号

完全加括号的矩阵链乘积可递归地定义为:

最优子结构

最优解的递推关系

 

Ai...j=Ai...kAk+1...j,k=i,i+1,...,j−1Ai...j=Ai...kAk+1...j,k=i,i+1,...,j−1

 

 

m[i][j]={mini≤k<j{m[i][k]+m[k+1][j]+Pi−1PkPj}0if i<jif i=jm[i][j]={mini≤k<j{m[i][k]+m[k+1][j]+Pi−1PkPj}if i<j0if i=j

 

算法描述(伪代码)

haskell
MatrixChain(P,n)
	令所有m[i,j]的初值为0;
	for r <- 2 to n   do
		for i <- 1 to n-r+1  do
			j <- i+r-1;
			m[i,j] <- m[i+1,j]+P_i-1P_iP_j;
			s[i,j] = i;
			for k <- i+1 to j-1  do
				t <- m[i,k]+m[k+1,j]+P_i-1P_kP_j;
				if t < m[i,j]
					then m[i,j] <- t;
						 s[i,j] <- k;

结束语

醉后不知天在水,满船清梦压星河

作者:花城

标签:链乘,...,括号,Ai,矩阵,A1,备忘录,最优
来源: https://www.cnblogs.com/wl-blog/p/15000956.html