矩阵链乘问题

关于算法导论上面的矩阵链乘问题,虽然书上说的很清楚,但是关于填写的规则,三重循环的下标的起点和终点

确实需要格外注意。

有三种填充方式,对角线,从下往上,从左往右,选择一种能顺利描述的就好

#include<fstream>
#include<iostream>
using namespace std;
const int  MAX_INT = 0x7fffffff;
void print(int s[][7], int i, int j)
{
    if (i == j) cout << "A"  << i;
    else {
        cout << "(";
         print(s, i, s[i][j]);
         print(s, s[i][j] + 1, j);
         cout << ")";
    }
}
int main()
{
    int p[7] = {30,35,15,5,10,20,25 };
    int m[8][8],s[7][7];
    int x,i,j,l,k,q;
    for (x=1; x <7; x++)
        m[x][x] = 0;
    for ( l = 2; l <= 6; l++)
    {
        for ( i = 1; i <= 7-l; i++)
        {
              j=i+l-1;
             m[i][j] = MAX_INT;
             int q;
        //     cout << m[i][j];
            for ( k = i; k <j; k++)
            {
                q = m[i][k] + m[k + 1][j] + p[i - 1] * p[k] * p[j];
                if (q < m[i][j]) {
                    m[i][j] = q;
                    s[i][j] = k;
                }
            }
        }
    }

    print(s, 1, 6);
    system("pause");
    return 0;
}

猜你喜欢

转载自www.cnblogs.com/blairwaldorf/p/9016310.html