Pagini recente » Cod sursa (job #3268007) | Cod sursa (job #2711877) | Cod sursa (job #1845465) | Cod sursa (job #1742383) | Cod sursa (job #3155882)
#include <iostream>
#include <climits>
using namespace std;
long long a[510];
long long dp[510][510];
int n;
const long long inf = LLONG_MAX;
int main()
{
ifstream cin("podm.in");
ofstream cout("podm.out");
cin>>n;
for(int i = 0;i <= n;i++)
cin>>a[i];
for(int i = 1;i < n;i++)
dp[i][i + 1] = a[i - 1] * a[i] * a[i + 1];
for(int lungime = 3;lungime <= n;lungime++)
{
for(int i = 1;i <= n - lungime + 1;i++)
{
int j = i + lungime - 1;
dp[i][j] = inf;
for(int k = i;k < j;k++)
dp[i][j] = min(dp[i][j],dp[i][k] + dp[k + 1][j] + a[i - 1] * a[k] * a[j]);
}
}
cout<<dp[1][n];
}