Cod sursa(job #3346310)

Utilizator pofianFilipp pofian Data 13 martie 2026 10:34:03
Problema Parantezare optima de matrici Scor 100
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.76 kb
// https://infoarena.ro/problema/podm
#include <bits/stdc++.h>
using namespace std;
ifstream fin ("podm.in");
ofstream fout("podm.out");

int main() {
    int n;
    fin >> n;

    vector<int64_t> v(n + 1);
    for (int i = 0; i <= n; i++)
        fin >> v[i];

    vector<vector<int64_t>> dp(n, vector<int64_t>(n));
    for (int i = 0; i < n; i++)
        dp[i][i] = 0;

    for (int l = 1; l < n; l++) {
        for (int i = 0, j = l; j < n; i++, j++) {
            int64_t best = 1e18;
            //   (Mi ... Mk) (Mk+1 ... Mj)
            for (int k = i; k < j; k++) {
                const int64_t c = dp[i][k] + v[i] * v[k+1] * v[j+1] + dp[k+1][j];
                best = min(best, c);
            }
            dp[i][j] = best;
        }
    }

    fout << dp[0][n - 1];
}