Pagini recente » Cod sursa (job #2235975) | Cod sursa (job #2236407) | Cod sursa (job #694763) | Cod sursa (job #2683712) | Cod sursa (job #2094387)
#include <fstream>
#include <algorithm>
using namespace std;
ifstream cin("oo.in");
ofstream cout("oo.out");
const int nmax=100000;
int n,v[nmax+5],dp[nmax+5];
int slove1()
{
dp[2]=v[1]+v[2];
for(int i=3;i<n;i++)
dp[i]=max(v[i]+v[i-1]+dp[i-3],dp[i-1]);
return dp[n-1];
}
int slove2()
{
swap(v[2],v[n]);
int X=slove1();
swap(v[2],v[n]);
return X;
}
int slove3()
{
dp[2]=0;
dp[3]=v[2]+v[3];
for(int i=4;i<=n;i++)
dp[i]=max(v[i]+v[i-1]+dp[i-3],dp[i-1]);
return dp[n];
}
int main()
{
cin>>n;
for(int i=1;i<=n;i++)
cin>>v[i];
cout<<max(slove1(),max(slove2(),slove3()));
return 0;
}