Cod sursa(job #648327)

Utilizator diehardNasturel Gabriel diehard Data 13 decembrie 2011 11:44:03
Problema Parantezare optima de matrici Scor 0
Compilator cpp Status done
Runda Arhiva educationala Marime 0.53 kb
#include<fstream.h>
#include<limits.h>
#include<iostream.h>

using namespace std;
#define NM 512
#define INF 1000000000LL
long long o[NM][NM],D[NM],n;
ifstream in("podm.in");
ofstream out("podm.out");


int main(){
	long long i,j,c,poz,d,k;
	in>>n;
	for(i=1;i<=n+1;i++) in>>D[i];
	for(d=1;d<=n-1;d++)
		for(poz=1;poz<=n-d;poz++){
			i=poz;
			j=d+poz;
			o[i][j]=INF;
			for(k=i;k<j;k++){
				long long min=o[i][k]+o[k+1][j]+D[i]*D[k+1]*D[j+1];
				if(min<o[i][j]) o[i][j]=min;
			}
		}
		out<<o[1][n];
		return 0;
}