Cod sursa(job #2407732)

Utilizator Dobricean_IoanDobricean Ionut Dobricean_Ioan Data 17 aprilie 2019 10:42:17
Problema Parantezare optima de matrici Scor 0
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.54 kb
#include <fstream>
using namespace std;

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


const int Dim = 501;
long long M[Dim][Dim],n,D[Dim];

int main() {
	
	fin >> n;
	fin >> D[1];
	for ( int i = 2; i <= n+1; ++i)  {
		fin >> D[i];
	}
	for ( int i = 1; i <= n; ++i)
		for ( int j= 1; j <= n; ++j)
			M[i][j] = 1LL << 58;
	for ( int l = 1; l <= n; ++l) 
		for ( int i = 1; i <= n-l+1; ++i) {
			
			int j = i + l - 1;
			for ( int k = i + 1; k < j; ++k) 
				M[i][j] = min(M[i][j],M[i][k] + M[k][j] + D[i] *D[k] * D[j]);
		} 
	fout << M[1][n];		
}