Pagini recente » Cod sursa (job #1701147) | Cod sursa (job #2887743) | Cod sursa (job #2933805) | Cod sursa (job #2599517) | Cod sursa (job #698089)
Cod sursa(job #698089)
#include <fstream>
using namespace std;
ifstream f("podm.in");
ofstream g("podm.out");
int n,d[512],a[512][512];
inline int minim(int a, int b)
{
return (a>b)?b:a;
}
int main()
{
int i,j,k;
f>>n;
for(i=0;i<=n;++i) f>>d[i];
for(i=1;i<n;++i) a[i][i+1]=d[i-1]*d[i]*d[i+1];
for(k=2;k<n;++k)
for(i=1;i+k<=n;++i)
{
a[i][i+k]=a[i][i]+a[i+1][i+k]+d[i-1]*d[i]*d[i+k];
for(j=2;j<i+k;++j) a[i][i+k]=minim(a[i][i+k],a[i][i+j-1]+a[i+j][i+k]+d[i-1]*d[i+j-1]*d[i+k]);
}
g<<a[1][n]<<'\n';
f.close(); g.close();
return 0;
}