Pagini recente » Cod sursa (job #2332824) | Cod sursa (job #221211) | Cod sursa (job #1876776) | Cod sursa (job #1561867) | Cod sursa (job #1556391)
#include <fstream>
#include <numeric>
#include <algorithm>
using namespace std;
const int MAX_N = 500 + 50;
const long long INF = numeric_limits <long long> :: max();
int v[MAX_N + 1];
long long D[MAX_N + 1][MAX_N + 1];
int main(void)
{
ifstream in("podm.in");
ofstream out("podm.out");
in.tie(0);
ios_base::sync_with_stdio(0);
int N;
in >> N;
for (int i = 0; i <= N; i++)
in >> v[i];
in.close();
for (int i = N - 1; i; i--)
{
for (int j = i + 1; j <= N; j++)
{
D[i][j] = INF;
for (int k = i; k < j; k++)
D[i][j] = min(D[i][j], D[i][k] + D[k + 1][j] + v[i - 1] * v[k] * v[j]);
}
}
out << D[1][N] << '\n';
out.close();
return 0;
}