Pagini recente » Cod sursa (job #2271100) | Cod sursa (job #2833572) | Cod sursa (job #1102993) | Cod sursa (job #352093) | Cod sursa (job #1417241)
#include <fstream>
#include <algorithm>
#include <math.h>
using namespace std;
int dp[4][100005];
int main() {
int n, i, result;
ifstream f("oo.in");
ofstream g("oo.out");
f >> n;
for(i = 1; i <= n; i++) {
f >> d[0][i];
}
d[0][n + 1] = d[0][1];
d[1][2] = d[0][1] + d[0][2];
for(i = 3; i < n; i++) {
x = d[1][i - 1];
y = d[1][i - 3] + d[0][i - 1] + d[0][i];
d[1][i] = max(x, y);
}
result = max(result, d[1][n - 1]);
for(i = 3; i <= n; i++) {
x = d[2][i - 1];
y = d[2][i - 3] + d[0][i - 1] + d[0][i];
d[2][i] = max(x, y);
}
result = max(result, d[1][n]);
for(i = 3; i < n; i++) {
x = d[3][i - 1];
y = d[3][i - 3] + d[0][i - 1] + d[0][i];
d[3][i] = max(x, y);
}
result = max(result, d[1][n + 1]);
g << result;
}