Pagini recente » Cod sursa (job #708966) | Cod sursa (job #732353) | Cod sursa (job #1583891) | Istoria paginii runda/simulare_shumen_4 | Cod sursa (job #1050731)
#include <fstream>
using namespace std;
ifstream f("buline.in");
ofstream g("buline.out");
int v[999999],n;
int main()
{
f>>n;
for (int i=1;i<=n;i++) {
int p;
f>>v[i]>>p;
if (p==0)
v[i] = -v[i];
}
int MaxEndingHere = v[1];
int MaxSum = v[1];
int end = 0, MaxStart = 0;
for (int i = 1; i <= n; i++) {
if (MaxEndingHere >= 0) {
MaxEndingHere += v[i];
} else {
MaxStart = i;
MaxEndingHere = v[i];
}
if (MaxEndingHere > MaxSum) {
MaxSum = MaxEndingHere;
end = i;
}
}
//seocnd pass
for (int i = 1; i < MaxStart; i++) {
if (MaxEndingHere > 0) {
MaxEndingHere += v[i];
} else {
break;
}
if (MaxEndingHere > MaxSum) {
MaxSum = MaxEndingHere;
end = i;
}
}
g << MaxSum << " " << MaxStart << " " << (n - MaxStart + end + 1);
f.close();
g.close();
}