Pagini recente » Cod sursa (job #2621155) | Cod sursa (job #1529369) | Cod sursa (job #2605209) | Cod sursa (job #888135) | Cod sursa (job #3167300)
#include <bits/stdc++.h>
using namespace std;
ifstream fin("buline.in");
ofstream fout("buline.out");
/*
struct buline
{
int value;
friend istream& operator>>(istream& os, buline &var)
{
short type;
os>>var.value>>type;
if(!type)
var.value *= -1;
return os;
}
};*/
struct answer
{
int value;
short start;
short length;
friend ostream& operator<<(ostream& os, answer &ans)
{
os<<ans.value<<' '<<ans.start<<' '<<ans.length;
}
} ans;
int n;
vector<short> v;
short x;
int leftie;
int i;
int mem;
int a,b;
int main()
{
fin>>n;
//buline aux;
fin>>a>>b;
if(!b)
a*=-1;
ans = {a, 1, 1};
v.push_back(a);
for( i = 2; i <= n; i++)
{
fin>>a>>b;
if(!b)
a*=-1;
x = a;
if(v.back() + x > x)
v.push_back(v.back() + x);
else
leftie=i,v.push_back(x);
if(v.back() > ans.value)
ans = {v.back(), leftie, i - leftie + 1};
}
/*
if(ans.length < n)
{
mem = v.back() + v[0];
if(ans.value < mem)
ans.value = mem, ans.length = ans.length + 1;
for( i = 1; i < leftie - 1; i++)
{
if(mem + v[i] > v[i])
mem += v[i];
if(ans.value < mem)
ans.value = mem, ans.length = ans.length + i + 1;
}
}
*/
fout<<ans;
return 0;
}