Pagini recente » Borderou de evaluare (job #2015877) | Cod sursa (job #539423) | Cod sursa (job #295716) | Cod sursa (job #920240) | Cod sursa (job #2376510)
#include <bits/stdc++.h>
using namespace std;
ifstream fin("oo.in");
ofstream fout("oo.out");
const int NMAX=100005;
int v[100005],dp[100005];
int main()
{
int sol, i, n;
fin>>n;
for(i=1;i<=n;i++)
fin>>v[i];
dp[1]=v[1];
dp[2]=v[1]+v[2];
for(i=3;i<n;i++)
dp[i]=max(dp[i-1], v[i]+v[i-1]+dp[i-3]);
sol=dp[n-1];
dp[1]=0;
dp[2]=v[2];
for(i=3;i<=n;i++)
dp[i]=max(dp[i-1], v[i]+v[i-1]+dp[i-3]);
sol=max(sol, dp[n]);
dp[1]=dp[2]=v[1]+v[n];
for(i=3;i<=n-2;i++)
dp[i]=max(dp[i-1], v[i]+v[i-1]+dp[i-3]);
sol=max(sol, dp[n-2]);
fout<<sol<<"\n";
return 0;
}