Cod sursa(job #3203976)

Utilizator vvvvvvvvvvvvvVusc David vvvvvvvvvvvvv Data 15 februarie 2024 09:42:27
Problema Parantezare optima de matrici Scor 70
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.64 kb
#include <fstream>

using namespace std;

ifstream fin("podm.in");
ofstream fout("podm.out");

const int NMAX = 502, INF = 1e9;
int n, d[NMAX], dp[NMAX][NMAX];

int min_chain(int i, int j){
    if(i == j) return 0;
    if(dp[i][j] != -1) return dp[i][j];
    dp[i][j] = INF;
    for(int k = i; k < j; k++) dp[i][j] = min(dp[i][j], min_chain(i, k) + min_chain(k + 1, j) + d[i - 1] * d[k] * d[j]);
    return dp[i][j];
}

int main()
{
    fin >> n;
    for(int i = 0; i <= n; i++) fin >> d[i];
    for(int i = 0; i <= n; i++)
        for(int j = 0; j <= n; j++)
            dp[i][j] = -1;
    fout << min_chain(1, n);
    return 0;
}