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

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

  • 相关阅读:
    tomcat 配置ssi
    oracle exp imp 导入 正在跳过表 plsql 导入表 成功终止 数据 被导入
    oracle 创建数据表空间和用户
    移动端开发来个总结吧
    ssl四次握手
    面试-布局
    typeof的原理?
    马上面试了就,复习一下排序
    关于webview无法设置页面标题
    关于let的生命提升
  • 原文地址:https://www.cnblogs.com/kedebug/p/2769016.html
Copyright © 2011-2022 走看看