Cod sursa(job #2669313)

Utilizator chriss_b_001Cristian Benghe chriss_b_001 Data 6 noiembrie 2020 18:43:23
Problema Parantezare optima de matrici Scor 100
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.71 kb
#include <fstream>

using namespace std;

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

const long long INF = 1LL << 62;

int N;
short int D[501];
long long M[500][500];

void calcul()
{
    for(int d = 1; d < N; ++d)
        for(int i = N - d - 1; i >= 0; --i)
        {
            int j = i + d;
            M[i][j] = INF;
            for(int k = i; k < j; ++k)
            {
                long long t = M[i][k] + M[k + 1][j] + 1LL * D[i] * D[k + 1] * D[j + 1];
                if(M[i][j] > t)
                    M[i][j] = t;
            }
        }
}

int main()
{
    f >> N;
    for(int i = 0; i <= N; ++i)
        f >> D[i];
    calcul();
    g << M[0][N - 1];
    return 0;
}