Cod sursa(job #2121143)

Utilizator Mihai145Oprea Mihai Adrian Mihai145 Data 3 februarie 2018 13:00:09
Problema Buline Scor 30
Compilator cpp Status done
Runda Arhiva de probleme Marime 0.95 kb
#include <bits/stdc++.h>
using namespace std;
ifstream fin("buline.in");
ofstream fout("buline.out");
long long n, v[400002], maxel=INT_MIN, s=INT_MIN, smax=INT_MIN, pozmaxel, inc, l;
int main()
{
    long long i, st, tip;
    fin>>n;
    for(i=1; i<=n; i++)
    {
        fin>>v[i]>>tip;
        if(tip==1) v[i+n]=v[i];
        else v[i]*=-1, v[i+n]=v[i];
        if(v[i]>maxel)
        {
            pozmaxel=i;
            maxel=v[i];
        }
    }
    for(i=1; i<=2*n; i++)
    {
        if(s<0) s=v[i], st=i;
        else s+=v[i];
        if(i-st+1>n)
        {
            while(i-st+1>n)
                s-=v[st], st++;
            while(v[st]<0 && st<i)
                s-=v[st], st++;
        }
        if(s>smax)
        {
            inc=st;
            l=i-st+1;
            smax=s;
        }
    }
    if(maxel>smax) fout<<maxel<<' '<<pozmaxel<<' '<<1<<'\n';
    else fout<<smax<<' '<<inc<<' '<<l<<'\n';
    return 0;
}