void recurMatrixChain(int n,int p[],int m[][],int s[][])
{
for(int r=2;r<=n;r++) //矩阵链长度
{
for(int i=1;i<=n-r+1;i++) //开始矩阵
{
int j=i+r-1; //结束矩阵
m[i][j]=m[i][i]+m[i+1][j]+p[i-1]*p[i]*p[j]; //初始化 假装在i处切开
s[i][j]=i;
for(int k=i+1;k<j;k++) //k 切开位置
{
int temp=m[i][k]+m[k+1][j]+p[i-1]*p[k]*p[j];
if(temp<m[i][j])
{
m[i][j]=temp;
s[i][j]=k;
}
}
}
}
}
矩阵连乘 (动态规划)
最新推荐文章于 2024-06-12 10:00:23 发布