Cod sursa(job #392008)

Utilizator cristikIvan Cristian cristik Data 6 februarie 2010 17:03:12
Problema Parantezare optima de matrici Scor 80
Compilator cpp Status done
Runda Arhiva educationala Marime 0.63 kb
#include <stdio.h>
#define max 1010
#define inf 0x3f3f3f3f
long long m[max][max],d[max],n,i,j,min,kmin,k,nr;
int main()
{
    freopen("podm.in","r",stdin);
    freopen("podm.out","w",stdout);
    scanf("%d",&n);
    for(i=0; i<=n; i++) scanf("%d",&d[i]);

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