zoj1276矩阵连乘dp

很经典的入门dp

/*******************************************************************************/
/* OS           : 3.2.0-58-generic #88-Ubuntu SMP Tue Dec 3 UTC 2013 GNU/Linux
 * Compiler     : g++ (GCC)  4.6.3 (Ubuntu/Linaro 4.6.3-1ubuntu5)
 * Encoding     : UTF8
 * Date         : 2014-03-23
 * All Rights Reserved by yaolong.
*****************************************************************************/
/* Description: ***************************************************************
*****************************************************************************/
/* Analysis: ******************************************************************
*****************************************************************************/
/*****************************************************************************/

#include<iostream>
#include<cstdio>
#include<cstring>
using namespace std;
#define INF 1<<30
#define MAX 100
int m[MAX][MAX],s[MAX][MAX],p[MAX];
void MatrixChain(int n){
    int i,j,l,q,k;
    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]=INF;

         for(k=i;k<=j-1;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;

            }
         }
       }

}
void trace_back(int i,int j){
    if(i==j) {cout<<"A"<<i; return;}
    cout<<"(";
    trace_back(i,s[i][j]);
    cout<<" x ";
    trace_back(s[i][j]+1,j);
    cout<<")";



}
int main(){
    #ifndef ONLINE_JUDGE
    freopen("in.txt","r",stdin);
    #endif
    int i,n,cases=1;
    while(cin>>n&&n){

     for(i=1;i<=n;i++){
        cin>>p[i-1]>>p[i];
     }
     cout<<"Case "<<cases++<<": ";
        MatrixChain(n);
        trace_back(1,n);
        cout<<endl;



    }

    #ifndef  ONLINE_JUDGE
    fclose(stdin);
    #endif

    return 0;

}



其实我觉得题目输入冗余太高了……完全没必要。。。。wa了一次,因为没有写case x: ..


转载于:https://www.cnblogs.com/dengyaolong/p/3697215.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值