Cod sursa(job #520010)

Utilizator dushmiMihai-Alexandru Dusmanu dushmi Data 7 ianuarie 2011 11:52:17
Problema Parantezare optima de matrici Scor 90
Compilator cpp Status done
Runda Arhiva educationala Marime 0.74 kb
#include<cstdio>
#include<fstream>
#define LL long long
using namespace std;
int n,a[1<<9];
LL d[1<<9][1<<9];
ifstream f("podm.in");
void read()
{
    freopen("podm.out","w",stdout);
    f>>n;
    for(int i=1;i<=n+1;i++)
        f>>a[i];
}
inline LL min(LL x,LL y)
{
    return x<y?x:y;
}
void solve()
{
    for(int i=n;i>=1;i--)
    {
        d[i][i]=0;
        d[i][i+1]=(LL)a[i]*a[i+1]*a[i+2];
        for(int j=i+2;j<=n;j++)
        {
            d[i][j]=d[i][i]+d[i+1][j]+(LL)a[i]*a[i+1]*a[j+1];
            for(int k=i+1;k<=j;k++)
                d[i][j]=min(d[i][j],d[i][k]+d[k+1][j]+(LL)a[i]*a[k+1]*a[j+1]);
        }
    }

}
int main()
{
    read();
    solve();
    printf("%lld",d[1][n]);
    return 0;
}