Pagini recente » Clasament simulare-cartita-22 | Cod sursa (job #472380) | Cod sursa (job #2276959) | Cod sursa (job #929814) | Cod sursa (job #2227776)
#include <iostream>
#include <fstream>
using namespace std;
long long n;
long long dp[510][510],a[510];
void fct()
{
long long x,y;
for(long long i=1;i<=n;i++)
for(long long j=1;j+1<=n;j++)
{
x=j;
y=i+j;
long long mini=(1LL<<60);
for(long long k=x;k<y;k++)
if(mini>dp[x][k]+dp[k+1][y]+a[x]*a[k+1]*a[y+1])
mini=dp[x][k]+dp[k+1][y]+a[x]*a[k+1]*a[y+1];
dp[x][y]=mini;
}
}
int main()
{
ifstream fin("podm.in");
fin>>n;
for(long long i=1;i<=n+1;i++)
fin>>a[i];
fct();
ofstream fout("podm.out");
fout<<dp[1][n];
return 0;
}