Cod sursa(job #1325656)

Utilizator YoChinezuWeng Mihai Alexandru YoChinezu Data 24 ianuarie 2015 11:27:08
Problema Parantezare optima de matrici Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.72 kb
#include <cstdio>
#include <algorithm>

using namespace std;

const int NMAX = 505;
const long long INF = 1LL << 60;

long long a[NMAX], dp[NMAX][NMAX];

int main() {
    freopen("podm.in", "r", stdin);
    freopen("podm.out", "w", stdout);

    int N;
    scanf("%d", &N);

    for(int i = 0; i <= N; ++ i) {
        scanf("%lld", &a[i]);
    }

    for(int l = 2; l <= N; ++ l) {
        for(int i = 1; i <= N - l + 1; ++ i) {
            int j = i + l - 1;
            dp[i][j] = INF;
            for(int k = i; k < j; ++ k) {
                dp[i][j] = min(dp[i][j], dp[i][k] + dp[k + 1][j] + a[i - 1] * a[k] * a[j]);
            }
        }
    }

    printf("%lld", dp[1][N]);

    return 0;
}