Pagini recente » Cod sursa (job #2213407) | Cod sursa (job #855608) | Cod sursa (job #637381) | Cod sursa (job #2918988) | Cod sursa (job #3211839)
#include <iostream>
#include <fstream>
using namespace std;
ifstream fin("oo.in");
ofstream fout("oo.out");
long long n,a[100005];
long long sol,dp[100005];
long long maxim(long long a,long long b)
{
if(a>b)
{
return a;
}
return b;
}
int main()
{
fin>>n;
for(int i=1;i<=n;i++)
{
fin>>a[i];
}
dp[1]=0;
dp[2]=a[1]+a[2];
for(int i=3;i<n;i++)
{
dp[i]=maxim(dp[i-1],a[i]+a[i-1]+dp[i-3]);
}
sol=dp[n-1];
dp[1]=0;
dp[2]=0;
for(int i=3;i<=n-3;i++)
{
dp[i]=maxim(dp[i-1],dp[i-3]+a[i-1]+a[i]);
}
sol=maxim(sol,dp[n-3]+a[n-1]+a[n]);
dp[3]=0;
for(int i=4;i<=n-2;i++)
{
dp[i]=maxim(dp[i-1],a[i]+a[i-1]+dp[i-3]);
}
sol=maxim(sol,dp[n-2]+a[n]+a[1]);
fout<<sol;
return 0;
}