Cod sursa(job #2357434)

Utilizator BotzkiBotzki Botzki Data 27 februarie 2019 13:20:25
Problema Oo Scor 100
Compilator cpp-64 Status done
Runda Arhiva de probleme Marime 0.87 kb
#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;
}