Cod sursa(job #2151349)

Utilizator andrei32576Andrei Florea andrei32576 Data 4 martie 2018 13:19:56
Problema Parantezare optima de matrici Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.68 kb
#include <fstream>
using namespace std;

long long bst[505][505],d[505];
int n,i,j,k,w;
long long INF=100000000000000000;

ifstream f("podm.in");
ofstream g("podm.out");

int main()
{
    f>>n;
    for(i=0;i<=n;i++)
        f>>d[i];

    for(i=1;i<=n;i++)
        bst[i][i] = 0;

    for(i=1;i<=n-1;i++)
        bst[i][i+1] = d[i-1]*d[i]*d[i+1];
    for(w=2;w<=n-1;w++)
    {
        for(i=1;i<=n-w;i++)
        {
            j=i+w;
            bst[i][j]=INF;
            for(k=i;k<=j-1;k++)
                bst[i][j] = min(bst[i][j], bst[i][k] + bst[k+1][j] + d[i-1]*d[k]*d[j]);
        }
    }
    g<<bst[1][n];

    f.close();
    g.close();
    return 0;
}