Pagini recente » Cod sursa (job #1481154) | Cod sursa (job #746480) | Cod sursa (job #2838808) | Cod sursa (job #2266798) | Cod sursa (job #2357434)
#include <fstream>
using namespace std;
ifstream fin("oo.in");
ofstream fout("oo.out");
const int NMAX=100000;
int v[NMAX+5],dp[NMAX+5];
int main()
{
int sol, i, n;
fin>>n;
for(i=1;i<=n;i++)
fin>>v[i];
///Relatia de recurenta va fi
///d[i]=max(d[i-1], v[i]+v[i-1]+d[i-3];
///cazul 1-il luam de la 1 si nu il luam pe n;
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];
/// cazul 2- il luam pe al doilea si nu il luam pe primul
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]);
/// cazul 3- il luam pe primul si pe al doilea
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;
}