Pagini recente » Monitorul de evaluare | Borderou de evaluare (job #1561742) | Cod sursa (job #694579) | Cod sursa (job #249253) | Cod sursa (job #3329151)
#include <fstream>
using namespace std;
ifstream cin("podm.in");
ofstream cout("podm.out");
unsigned long long n,Dim[501],PD[501][501],k,i,j,x;
int main()
{
cin>>n;
for(i=0;i<=n;i++)
cin>>Dim[i];
for(i=1;i<=n;i++) PD[i][i]=0;
for(i=2;i<=n;i++)
for(x=1;i+x-1<=n;x++) {
j=i+x-1;
PD[x][j]=PD[x][x]+PD[x+1][j]+Dim[x-1]*Dim[x]*Dim[j];
for(k=x;k<j;k++)
{
PD[x][j]=min(PD[x][k]+PD[k+1][j]+Dim[x-1]*Dim[k]*Dim[j],PD[x][j]);
}
}
cout<<PD[1][n];
}