Cod sursa(job #3211838)

Utilizator lazureanrLazurean Razvan lazureanr Data 10 martie 2024 14:53:39
Problema Subsir crescator maximal Scor 0
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.84 kb
#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;
}