Pagini recente » Cod sursa (job #1820774) | Cod sursa (job #1152403) | Cod sursa (job #641987) | Cod sursa (job #1971309) | Cod sursa (job #371201)
Cod sursa(job #371201)
#include<cstdio>
using namespace std;
#define MAX_N 512
#define Inf 100000000000000000LL
#define ll long long
ll bst[MAX_N][MAX_N];
int d[MAX_N], N;
int main()
{
freopen("podm.in","r",stdin);
freopen("podm.out","w",stdout);
scanf("%d",&N);
int i,j,k,lg;
ll tmp;
for(i=1;i<=N+1;++i) scanf("%d",&d[i]);
for(i=1;i<=N;++i)
{
for(j=1;j<=N;++j) bst[i][j] = Inf;
bst[i][i] = 0;
}
for(lg = 1; lg <= N; ++lg)
{
for(i=1; i + lg - 1 <= N; ++i)
{
j = lg + i - 1;
for(k = i; k <= j; ++k)
{
tmp = bst[i][k-1] + bst[k][j] + (ll)d[i] * d[k] * d[j+1];
if(tmp < bst[i][j] ) bst[i][j] = tmp;
}
}
}
printf("%lld\n",bst[1][N]);
return 0;
}