Mai intai trebuie sa te autentifici.
Cod sursa(job #819564)
Utilizator | Data | 19 noiembrie 2012 12:27:26 | |
---|---|---|---|
Problema | Parantezare optima de matrici | Scor | 0 |
Compilator | cpp | Status | done |
Runda | Arhiva educationala | Marime | 0.56 kb |
#include<cstdio>
int d[1001][1001],i,j,pre,v[1001][1001],n,a[1000],k;
int minim(int x ,int y)
{
return (x<y) ? x:y;
}
int main()
{
freopen("pdm.in","r",stdin);
freopen("pdm.out","w",stdout);
scanf("%d",&n);
for(i=1; i<=n+1; ++i)
scanf("%d",&a[i]);
for(i=n; i>=1; --i)
{
for(j=i+1; j<=n; j++)
{
pre=999999999;
for(k=i; k<j; ++k)
pre=minim(pre,v[i][k]+v[k+1][j]+a[i]*a[k+1]*a[j+1]);
v[i][j]=pre;
}
}
printf("%d",v[1][n]);
}