Cod sursa(job #2320508)

Utilizator VadimCCurca Vadim VadimC Data 14 ianuarie 2019 20:34:11
Problema Parantezare optima de matrici Scor 100
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.77 kb
#include <iostream>
#include <fstream>

using namespace std;

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

#define NMax 510
#define ll long long
long long inf = (1e18);

int n;
int d[NMax];
long long c[NMax][NMax];

void init();
ll rezolvare(int, int);

int main(){
	init();
	rezolvare(1, n);
	fout << c[1][n];
}

void init(){
	int i, j;
	fin >> n;
	for(i = 0; i <= n; i++)
		fin >> d[i];
	
	for(i = 1; i <= n; i++)
		for(j = 1; j <= n; j++)
			c[i][j] = inf;
}

ll rezolvare(int i, int j){
	ll p;
	if(c[i][j] < inf) return c[i][j];
	if(i == j)
		c[i][j] = 0;
	else
		for(int k = i; k < j; k++){
			p = rezolvare(i, k) + rezolvare(k + 1, j) + 1LL * d[i - 1] * d[k] * d[j];
			if(p < c[i][j]) c[i][j] = p;
		}
	return c[i][j];
}