白日梦想jun 2016-05-03 12:47 采纳率: 100%
浏览 3077
已采纳

算法 矩阵连乘 代码问题

#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(")");
}
}
//程序一运行貌似是指针越界类问题,就停止了,谢谢指导。

  • 写回答

1条回答 默认 最新

报告相同问题?

悬赏问题

  • ¥15 ELGamal和paillier计算效率谁快?
  • ¥15 file converter 转换格式失败 报错 Error marking filters as finished,如何解决?
  • ¥15 ubuntu系统下挂载磁盘上执行./提示权限不够
  • ¥15 Arcgis相交分析无法绘制一个或多个图形
  • ¥15 关于#r语言#的问题:差异分析前数据准备,报错Error in data[, sampleName1] : subscript out of bounds请问怎么解决呀以下是全部代码:
  • ¥15 seatunnel-web使用SQL组件时候后台报错,无法找到表格
  • ¥15 fpga自动售货机数码管(相关搜索:数字时钟)
  • ¥15 用前端向数据库插入数据,通过debug发现数据能走到后端,但是放行之后就会提示错误
  • ¥30 3天&7天&&15天&销量如何统计同一行
  • ¥30 帮我写一段可以读取LD2450数据并计算距离的Arduino代码