Cod sursa(job #369820)

Utilizator mihai_floreaFlorea Mihai Alexandru mihai_florea Data 29 noiembrie 2009 17:01:16
Problema Parantezare optima de matrici Scor 90
Compilator c Status done
Runda Arhiva educationala Marime 0.66 kb
#include <stdio.h>
#define NMAX 512
#define LL long long
#define INF 99999999999999999LL
int N,d[NMAX];
LL T[NMAX][NMAX];
int main()
{
    int i,j,k;
    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=N;i;--i)
    {
        T[i][i]=0;
        for (j=i+1;j<=N;++j)
        {
            LL min=INF,aux=(LL)d[i-1]*d[j];;
            for (k=i;k<j;++k)
            {
                LL ret=T[i][k]+T[k+1][j]+aux*d[k];
                if (ret<min) min=ret;
            }
            T[i][j]=min;
        }
    }
    printf("%lld",T[1][N]);
    return 0;
}