Cod sursa(job #2077709)
| Utilizator | Data | 28 noiembrie 2017 14:41:32 | |
|---|---|---|---|
| Problema | Parantezare optima de matrici | Scor | 100 |
| Compilator | cpp | Status | done |
| Runda | Arhiva educationala | Marime | 0.64 kb |
#include<fstream>
using namespace std;
ifstream fin("podm.in");
ofstream fout("podm.out");
unsigned long long n,i,j,k,l;
unsigned long long D[505][505];
unsigned long long v[505];
int main(){
fin>>n;
for(i=1;i<=n+1;i++){
fin>>v[i];
}
for(i=1;i<=n;i++){
D[i][i]=0;
D[i][i+1]=0;
}
D[n+1][n+1]=0;
for(l=3;l<=n+1;l++){
for(i=1;l+i-1<=n+1;i++){
j=i+l-1;
D[i][j]=20000000000000000005;
for(k=i+1;k<j;k++){
D[i][j]=min(D[i][j],D[i][k]+D[k][j]+v[k]*v[i]*v[j]);
}
}
}
fout<<D[1][n+1];
return 0;
}
