Chinaunix首页 | 论坛 | 博客
  • 博客访问: 438252
  • 博文数量: 103
  • 博客积分: 5010
  • 博客等级: 大校
  • 技术积分: 971
  • 用 户 组: 普通用户
  • 注册时间: 2007-06-11 17:22
文章分类
文章存档

2008年(77)

2007年(26)

我的朋友

分类: C/C++

2008-04-17 22:14:46

算法描述:
矩阵Ai*Ai+1*...*Aj简记为A[i:j],所需的最小计算次数为m[i][j].
当i=j时,m[i][j] = 0
当i

#include <stdio.h>
#include <stdlib.h>

#define MAX_MATRIXNUM 100
#define MAX_VALUE 32767

int p[MAX_MATRIXNUM+1], m[MAX_MATRIXNUM+1][MAX_MATRIXNUM+1], s[MAX_MATRIXNUM+1][MAX_MATRIXNUM+1];
static void matrix_chain(int num);
static void traceback(int i, int j);

int main(int argc, char **argv)
{
        int i, num;

        printf("Input matrix num: ");
        scanf("%d", &num);
        getchar();

        printf("Input matrix subscript: ");
        for(i = 0; i <= num; i++){
                scanf("%d", &p[i]);
        }
        getchar();

        matrix_chain(num);
        traceback(1, num);
        printf("\n");

        return 0;
}

static void matrix_chain(int num)
{
        int i, j, l, k, n, temp;

        n = num;
        for(i = 1; i <= n; i++){
                m[i][i] = 0;
        }

        for(l = 2; l <= n; l++){
                for(i = 1; i <= n-l+1; i++){
                        j = i + l - 1;
                        m[i][j] = MAX_VALUE;
                        for(k = i; k < j; k++){
                                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;
                                }
                        }
                }
        }
        printf("The lowest compute times = %d\n", m[1][num]);
}

static void traceback(int i, int j)
{
        if(i == j){
                printf("A%d", i);
        }
        if(i < j){
                printf("(");
                traceback(i, s[i][j]);
                traceback(s[i][j]+1, j);
                printf(")");
        }
}

执行结果:

共6个矩阵,下标分别为:

30*35

35*15

15*5

5*10

10*20

20*25

[xxxx@localhost suanfa]$ ./a.out
Input matrix num: 6
Input matrix subscript: 30 35 15 5 10 20 25
The lowest compute times = 15125
((A1(A2A3))((A4A5)A6))

阅读(8565) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~