Pagini recente » Cod sursa (job #1922342) | Cod sursa (job #2267193) | Cod sursa (job #1045582) | Cod sursa (job #2071980) | Cod sursa (job #2645005)
#include <iostream>
#include<fstream>
using namespace std;
ifstream f("buline.in");
ofstream g("buline.out");
int n,suma,max1=-1000001,st,dr,contor,v[200001],k,ok,min1,ok1;
void citire()
{
f>>n;
int x,c;
for(int i=1;i<=n;i++)
{
f>>x>>c;
if(c==0)
v[i]=-x;
else
v[i]=x;
}
}
void minim()
{
min1=v[1];
for(int i=2;i<=n;i++)
if(v[i]<min1)
min1=v[i];
}
void rezolvare()
{
while(ok1==0)
{
k++;
if(v[k]==min1 && ok==1)
ok1=1;
if(suma<0)
suma=v[k],contor=k;
else
suma=suma+v[k];
if(suma>max1)
{
max1=suma;
st=contor;
dr=k;
}
if(k==n)
{
k=0;
ok=1;
}
}
if(ok==1)
g<<max1<<" "<<st<<" "<<dr-st+n+1;
else
g<<max1<<" "<<st<<" "<<dr-st;
}
int main()
{
citire();
minim();
rezolvare();
return 0;
}