Cod sursa(job #1563939)
Utilizator | Data | 7 ianuarie 2016 13:34:24 | |
---|---|---|---|
Problema | Parantezare optima de matrici | Scor | 70 |
Compilator | cpp | Status | done |
Runda | Arhiva educationala | Marime | 0.57 kb |
#include<cstdio>
#include<algorithm>
using namespace std;
int d[501],n,i,j,a[501][501],k;
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(i=1;i<=n;i++)
a[i][i]=0;
for(i=1;i<n;i++)
a[i][i+1]=d[i-1]*d[i]*d[i+1];
for(j=2;j<n;j++)
{
for(i=1;i<=n-j;i++)
{
int minim=1000000000;
for(k=i;k<i+j;k++)
minim=min(minim,a[i][k]+a[k+1][i+j]+d[i-1]*d[k]*d[i+j]);
a[i][i+j]=minim;
}
}
printf("%d",a[1][n]);
}