Pagini recente » Cod sursa (job #1069008) | Cod sursa (job #1610496) | Cod sursa (job #268240) | Cod sursa (job #1772696) | Cod sursa (job #2849364)
#include <fstream>
using namespace std;
ifstream fin("oo.in");
ofstream fout("oo.out");
///d1=nr maxim de oua adunate incepand cu sectoarele 1 2
///d2=nr maxim de oua adunate incepand cu sectoarele n 1
///d3=nr maxim de oua adunate incepand cu sectoarele 2 3
int n, v[100001], d1[100001], d2[100001], d3[100001];
int main()
{
fin>>n;
for(int i=1; i<=n; i++)
{
fin>>v[i];
}
d1[2]=d1[3]=v[1]+v[2];
d2[1]=v[n]+v[1];
d3[3]=v[2]+v[3];
for(int i=4; i<=n; i++)
{
if(i<n-1)
{
d2[i]=max(d2[i-1], d2[i-3]+v[i]+v[i-1]);
}
if(i<n)
{
d1[i]=max(d1[i-1], d1[i-3]+v[i]+v[i-1]);
}
d3[i]=max(d3[i-1], d3[i-3]+v[i]+v[i-1]);
}
fout<<max(d1[n-1], max(d3[n], d2[n-2]));
return 0;
}