Pagini recente » Cod sursa (job #2061710) | Cod sursa (job #1962923) | Cod sursa (job #2817219) | Cod sursa (job #583799) | Cod sursa (job #3183780)
#include <iostream>
#include <fstream>
#include <vector>
using namespace std;
ifstream fin("buline.in");
ofstream fout("buline.out");
vector <int> v;
int t,a,n,s,l,p,smax,u,best[200005];
int main()
{
fin>>n;
for(int i=1;i<=n;i++)
{
fin>>a>>t;
if(t==1){v.push_back(a);}
else{v.push_back((-1)*a);}
}
for(int i=0;i<n-1;i++)
{
v.push_back(v[i]);
}
best[0]=v[0];
smax=v[0];
for(int i=1;i<=2*n-3;i++)
{
best[i]=max(best[i-1]+v[i],v[i]);
smax=max(smax,best[i]);
}
for(int i=0;i<=2*n-3;i++)
{
if(best[i]==smax)
{
int j=i;
u=i;
while(j>0)
{
j--;
p=j;
if(best[j]<0)
{
break;
}
}
break;
}
}
fout<<smax<<" "<<p+2<<" "<<u-p;
fin.close();
fout.close();
return 0;
}