zoukankan      html  css  js  c++  java
  • hoj 1071 最大矩阵连乘次数

    最大矩阵连乘次数

    Time Limit:500MS  Memory Limit:65536K
    Total Submit:128 Accepted:72

    Description

    给定n个矩阵{A1,A2,…,An},其中Ai与Ai+1是可乘的,i=1,2 ,…,n-1。如何确定计算矩阵连乘积的计算次序,使得依此次序计算矩阵连乘积需要的数乘次数最大。

    Input

    输入包含多组测试数据。第一行为一个整数C,表示有C组测试数据,接下来有2*C行数据,每组测试数据占2行,每组测试数据第一行是1个整数n(n≤10),表示有n个矩阵连乘,接下来一行有n+1个数,表示是n个矩阵的行及第n个矩阵的列,它们之间用空格隔开.

    Output

    你的输出应该有C行,即每组测试数据的输出占一行,它是计算出的矩阵最大连乘积次数.

    Sample Input

    1
    3
    10 100 5 50

    Sample Output

    75000

    Source

    wangzhiqun

    [Submit]   [Go Back]   [Status]   [Discuss]

     

    //13241 wupanlei 1071 Accepted 868K 15MS G++ 0.66K 2009-06-25 20:13:25 
    #include <iostream>
    #define MAX 1000
    using namespace std;
    int dp[MAX][MAX],p[MAX],n;
    void Init()
    {
        
    int i;
        
    for(i=0;i<=n;i++)
        {
            scanf(
    "%d",&p[i]);
        }
    }
    void MatrixChain()
    {
        
    int i,r,j,k;
        
    for(i=1;i<=n;i++)
            dp[i][i]
    =0;
        
    for(r=2;r<=n;r++)
            
    for(i=1;i<=n-r+1;i++)
            {
                j
    =r+i-1;
                dp[i][j]
    =dp[i][i]+dp[i+1][j]+p[i-1]*p[i]*p[j];
                
    for(k=i;k<j;k++)
                {
                    
    int temp=dp[i][k]+dp[k+1][j]+p[i-1]*p[k]*p[j];
                    
    if(temp>dp[i][j])
                        dp[i][j]
    =temp;
                }
            }
        printf(
    "%d\n",dp[1][n]);
    }
    int main()
    {
        
    int T;
        scanf(
    "%d",&T);
        
    while(T--)
        {
            scanf(
    "%d",&n);
            Init();
            MatrixChain();
        }
        
    return 0;
    }

     

  • 相关阅读:
    Stalstack 连接管理配置
    Stalstack 安装
    Apache 错误整理
    Apache 服务常用命令
    Apache 优化
    Shell 常用技巧
    Nginx+keepalived做双机热备加tomcat负载均衡
    用Lighttpd做图片服务器
    rsync是类unix系统下的数据镜像备份工具
    redis+keeplived分布式缓存
  • 原文地址:https://www.cnblogs.com/forever4444/p/1511213.html
Copyright © 2011-2022 走看看