Cod sursa(job #518373)

Utilizator BlaugranasEnal Gemaledin Blaugranas Data 31 decembrie 2010 12:43:27
Problema Parantezare optima de matrici Scor 0
Compilator cpp Status done
Runda Arhiva educationala Marime 0.68 kb
#include<stdio.h>
unsigned long long a[501][501],m;
int dim[501],i,n,j,d,k,v[501];

int main()
{freopen("podm.in","r",stdin);
freopen("podm.out","w",stdout);
scanf("%d\n",&n);
for(i=0;i<=n;i++)
       scanf("%d",&dim[i]);
for(i=1;i<=n;i++)
       a[i][i]=0;
for(i=1;i<=n-1;i++)
       a[i][i+1]=dim[i-1]*dim[i]*dim[i+1];
for(d=2;d<n;d++)
       {for(i=1;i<=n-d;i++)
               {a[i][i+d]=1000000000000;
               for(k=i;k<i+d;k++)
                        {m=a[i][k]+a[k+1][i+d]+dim[i-1]*dim[k]*dim[i+d];
                        if(a[i][i+d]>m)
                                 a[i][i+d]=m;}}}
printf("%llu\n",a[1][n]);
fclose(stdin);
fclose(stdout);
return 0;}