Cod sursa(job #2094387)

Utilizator FunnyStockyMihnea Andreescu FunnyStocky Data 25 decembrie 2017 19:31:40
Problema Oo Scor 50
Compilator cpp Status done
Runda Arhiva de probleme Marime 0.68 kb
#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;
}