Pagini recente » Cod sursa (job #2976499) | Cod sursa (job #15176) | Cod sursa (job #1252804) | Cod sursa (job #2365475) | Cod sursa (job #2493358)
#include <iostream>
#include <fstream>
#include <algorithm>
using namespace std;
long long dim[505], n;
long long dp[500][500];
void dinamica(){
for (int i = 1; i <= n; ++i) {
dp[i][i] = 0;
}
for (int i = 1; i <= n - 1; ++i) {
dp[i][i + 1] = dim[i-1] * dim[i] * dim[i + 1];
}
for (int d = 1; d < n; ++d) {
for (int i = 1; i <= n - d; ++i) {
int mini = 1010110101;
for (int k = i; k < i + d; ++k) {
mini = min(mini, dp[i][k] + dp[k + 1][i + d] + dim[i - 1] * dim[k] * dim[i + d]);
}
dp[i][i + d] = mini;
}
}
}
int main() {
ifstream f("podm.in");
ofstream g("podm.out");
f>>n;
for (int i = 0; i < n + 1; ++i) {
f>>dim[i];
}
dinamica();
g<<dp[1][n];
return 0;
}