zoukankan      html  css  js  c++  java
  • UVa 348 Optimal Array Multiplication Sequence(链式DP/区间DP)

    题意:

    有N个矩阵相乘,不同的相乘顺序会有不同的次数,求一种顺序,使相乘的次数最小。

    思路:

    简单的区间DP,麻烦的是要把这个顺序打印出来,要用到递归,需要学习,第二次碰到。

    #include <cstdio>
    #include <cstdlib>
    #include <cstring>
    #include <climits>
    
    long long int dp[15][15];
    int a[15], path[15][15];
    int n;
    
    void print(int i, int j)
    {
        if (i == j)
            printf("A%d", i + 1);
        else
        {
            printf("(");
            print(i, path[i][j]);
            printf(" x ");
            print(path[i][j] + 1, j);
            printf(")");
        }
    }
    
    int main()
    {
        int cases = 0;
        while (scanf("%d", &n) && n)
        {
            for (int i = 0; i < n; ++i)
                scanf("%d %d", &a[i], &a[i+1]);
    
            memset(dp, 0,  sizeof(dp));
            memset(path, 0, sizeof(path));
    
            for (int d = 1; d < n; ++d)
            {
                for (int i = 0, j = d; j < n; ++i, ++j)
                {
                    dp[i][j] = LLONG_MAX;
                    for (int k = i; k < j; ++k)
                    {
                        int t = dp[i][k] + dp[k+1][j] + a[i] * a[k+1] * a[j+1];
                        if (dp[i][j] > t)
                            dp[i][j] = t, path[i][j] = k;
                    }
                }
            }
            printf("Case %d: ", ++cases); 
            print(0, n - 1);
            printf("\n");
        }
        return 0;
    }
    -------------------------------------------------------

    kedebug

    Department of Computer Science and Engineering,

    Shanghai Jiao Tong University

    E-mail: kedebug0@gmail.com

    GitHub: http://github.com/kedebug

    -------------------------------------------------------

  • 相关阅读:
    简单的自我介绍
    学习总结(北航助教陈彦吉)
    2019春季第十二周助教总结
    2019春季第十一周助教总结
    第十一周作业
    2019春季第十周助教总结
    2019春季第九周助教总结
    第九周作业
    2019春季第八周助教总结
    第八周作业
  • 原文地址:https://www.cnblogs.com/kedebug/p/2769016.html
Copyright © 2011-2022 走看看