Cod sursa(job #394145)

Utilizator cristikIvan Cristian cristik Data 10 februarie 2010 16:56:27
Problema Parantezare optima de matrici Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.61 kb
#include <stdio.h>
#define max 502
#define inf 0x3f3f3f3f
long long m[max][max],d[max];
int n,i,j,k,nr;
int main()
{
    freopen("podm.in","r",stdin);
    freopen("podm.out","w",stdout);
    scanf("%d",&n);
    for(i=1; i<=n+1; i++) scanf("%lld",&d[i]);

    for(nr=2; nr<=n; nr++)
     for(i=1; i<=n-nr+1; i++)
     {
         j=i+nr-1;
         m[i][j]=1000000000000000LL;
         for(k=i; k<j; k++)
          if(m[i][j]>m[i][k]+m[k+1][j]+d[i]*d[k+1]*d[j+1])
          {
              m[i][j]=m[i][k]+m[k+1][j]+d[i]*d[k+1]*d[j+1];
          }
     }
    printf("%lld",m[1][n]);
    return 0;
}