Pagini recente » Cod sursa (job #2379830) | Cod sursa (job #2392068) | Cod sursa (job #2279763) | Cod sursa (job #3139544) | Cod sursa (job #2121143)
#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;
}