2 oiu1010110 oiu1010110 于 2016.05.03 20:47 提问

算法 矩阵连乘 代码问题

#include
#include
#define Num 7
void MatrixChain(int *p,int n,int (*m)[Num],int (*s)[Num]);
void Traceback(int i,int j,int (*s)[Num]);
void main()
{

int p[Num] = {30,35,15,5,10,20,25};
int m[Num][Num];
int s[Num][Num];


MatrixChain(p,Num-1,m,s);


/*for(int i = 1;i<=Num;i++)
{
    for(int j = 1; j<=Num ;j++)
    {
        if(j >= i){
            printf("%d",s[i][j]);
        }
    }
    printf("\n");
}*/                           //为什么s[Num][Num]的值没有变呢?

// Traceback(1,Num,s);

}

void MatrixChain(int p,int n,int (*m)[Num],int (*s)[Num])
{
for(int i = 1;i<=n;i++) //初始化对角线
{
m[i][i] = 0;
}
for(int r = 2;r<=n;r++)//多少个对角线
{
for(int i = 1;i < n-r+1;i++) //
*m中行的控制
{
int j = i+r-1; //**m中列的控制

        m[i][j] = m[i+1][j] + p[j-1]*p[i]*p[j];  
        s[i][j] = i;

        for(int k = i+1; k<j;k++)
        {
            int t = m[i][k] + m[k+1][j] + p[i-1]*p[k]*p[j];
            if(t < m[i][j])
            {
                m[i][j] = t;        //记录最小值
                s[i][j] = k;       //记录最小的来源
            }
        }
    }
}

}

void Traceback(int i,int j,int (*s)[Num])
{
if(i==j)
{
printf("A%d",i);
}
else
{
printf("(");
Traceback(i,s[i][j],s);
Traceback(s[i][j]+1,j,s);
printf(")");
}
}
//程序一运行貌似是指针越界类问题,就停止了,谢谢指导。

2个回答

caozhy
caozhy   Ds   Rxr 2016.05.04 07:10
已采纳
CSDNXIAON
CSDNXIAON   2016.05.03 20:52

矩阵连乘问题的算法分析
算法动态规划问题之矩阵连乘
矩阵连乘问题
----------------------同志你好,我是CSDN问答机器人小N,奉组织之命为你提供参考答案,编程尚未成功,同志仍需努力!

Csdn user default icon
上传中...
上传图片
插入图片
准确详细的回答,更有利于被提问者采纳,从而获得C币。复制、灌水、广告等回答会被删除,是时候展现真正的技术了!
其他相关推荐
动态规划经典算法之矩阵连乘问题源代码
//Dynamic Programming经典算法之矩阵连乘链问题 //Author: milo //Email: 498638441@qq.com //Date: 2011/11/16 16:50 #include #include #include static int m[6][6];//m[i][j]存储子问题的最优解 static int s[6][6];//
C++动态规划解决矩阵连乘问题
#include #include using namespace std; fun(int l,int n,int m[]) { int i,j,k,r; int **a = new int*[n]; for(i=0;i<n;i++) { a[i] = new int[n]; } for(i=0;i<n;i++) { for(j=0;j<n;j++) { a[i][j]
dp算法求解矩阵连乘的问题
利用动态规划算法解决矩阵连乘问题
矩阵连乘问题(C++)
Description 给定n个矩阵{A0,A1,…,An-1}, 其中Ai,i=0,…,n-1的维数为pi*pi+1,并且Ai与Ai+1是可乘的。考察这n个矩阵的连乘积A0A1…An-1,由于矩阵乘法满足结合律,所以计算矩阵的连乘可有许多不同的计算次序。矩阵连乘问题是确定计算矩阵连乘积的计算次序,使得按照这一次序计算矩阵连乘积,需要的“数乘”次数最少。Input第一行输入n的值,第二行输入n个
动态规划算法——矩阵连乘问题(java实现)
矩阵连乘问题: 求矩阵A1(5×3)、A2(3×4)、A3(4×7)、A4(7×2)、A5(2×3)和A6(3×6)连乘的最佳计算次序。  算法实现:package practice; /** * array[i][j] * 表示Ai...Aj的最佳计算次序所对应的相乘次数 即存放各子问题的最优值 * s[i][j]=k * 表示Ai...Aj这(j-i+1)个矩阵中最优加括号
Java算法3--动态规划算法实现矩阵连乘
一、需求 1、编写用动态规划算法实现矩阵连乘的类。 2、编写一个测试类,给出矩阵链的阶,求计算该矩阵链乘积的完全加括号方式的最小代价,用二维表的形式输出各子矩阵链的最优值。 二、实现源程序 (1)算法实现类程序: public class Matrix{ //计算最优值 public void matrixChain(int[]p, int[][]m, int [][]s) {
矩阵连乘问题 C语言实现
矩阵连乘问题,,求加括号的位置
算法 矩阵连乘 递归+动态规划+备忘录
题目给定n个矩阵,其中两个相邻的矩阵是可乘的,试求出最佳计算次序,使得总计算量最少。例如: A1[30X35] A2[35X15] A3[15X5] A4[5X10] A5[10X20] A6[20X25]代码1、递归算法#include <stdio.h> #define N 6int m[N+1][N+1];//最小乘法次数 int p[N+1]={30,35,15,5,10,
C语言实现矩阵连乘问题
#include #include using namespace std; //矩阵连乘问题 void MatrixChain(int *p,int n,int **m,int **s) { for(int i=1;i for(int r = 2;r for(i = 1;i { int j = i+r-1; m[i][j] = m[i+1][j]+p[i
矩阵连乘问题的算法分析
问题描述:给定n个矩阵:A1,A2,...,An,其中Ai与Ai+1是可乘的,i=1,2...,n-1。确定计算矩阵连乘积的计算次序,使得依此次序计算矩阵连乘积需要的数乘次数最少。输入数据为矩阵个数和每个矩阵规模,输出结果为计算矩阵连乘积的计算次序和最少数乘次数。       问题解析:由于矩阵乘法满足结合律,故计算矩阵的连乘积可以有许多不同的计算次序。这种计算次序可以用加括号的方式来确定。