Cod sursa(job #73071)
#include<fstream.h>
long a[400000],x,y,N,S,in,lg,max=-10211431;
void citire(){
ifstream fin("buline.in");
fin>>N;
for (long i=0;i<N;i++){
fin>>x>>y;
if (y==0){
a[i]=(-1)*x;
a[i+N]=a[i];}
else {
a[i]=x;
a[i+N]=a[i];}}
fin.close();
}
void maxim(){
int lg1=0;
for (long i=0;i<N+N;i++){
S+=a[i];
if (S<0){
S=0;
in=i+1;}
if (S>max){
max=S;
lg=i-in;}
if (lg1<N-1)
lg1=i-in;
else
break;}
}
int main(){
ofstream fout("buline.out");
citire();
maxim();
fout<<max<<" "<<in+1<<" "<<lg+1<<"\n";
fout.close();
return 0;
}