Pagini recente » Cod sursa (job #2497166) | Cod sursa (job #1709867) | Cod sursa (job #2896814) | Cod sursa (job #1281517) | Cod sursa (job #2110703)
#include <fstream>
using namespace std;
ifstream fin("buline.in");
ofstream fout("buline.out");
int v[200005];
int main()
{
int n;
fin >> n;
for(int i = 1; i <= n; ++i)
{
int x, o;
fin >> x >> o;
v[i] = x;
if(o == 0)
v[i] = -v[i];
v[n + i] = v[i];
}
int st = 1, rez = 1, s = 0, I = 0, N = 0, sm = 0;
for(int i = 1; i <= 2 * n; ++i)
{
s += v[i];++rez;
if(st + n == i)
s = -v[i], rez--, st++;
if(s > sm)
sm = s, I = st, N = rez;
if(s <= 0)
{
s -= v[i];
if(s > sm)
sm = s, I = st, N = rez;
s = 0, rez = 0, st = i + 1;
}
}
fout << sm << ' ' << I << ' ' << N << '\n';
return 0;
}