Pagini recente » Cod sursa (job #393673) | Cod sursa (job #2902254) | Cod sursa (job #140219) | Cod sursa (job #147417) | Cod sursa (job #2430722)
#include <iostream>
#include <fstream>
#include <climits>
std::ifstream fin("podm.in");
std::ofstream fout("podm.out");
int n;
int d[550];
long long m[550][550];
int main()
{
fin>>n;
for(int i=0;i<=n;i++)
fin>>d[i];
for(int i=0;i<n;i++)
m[i][i+1]=d[i]*d[i+1]*d[i+2];
for(int i=n;i>=0;i--)
for(int k=2;i+k<=n;k++)
{
long long minn = LONG_LONG_MAX;
for(int j=0;j<k;j++)
minn = std::min(minn, m[i][i+j]+m[i+j+1][i+k]+d[i]*d[i+j+1]*d[i+k]);
m[i][i+k]=minn;
}
fout<<m[0][n];
}