Cod sursa(job #2909257)

Utilizator TheGarbageWeebIonescu Ioan-Andrei TheGarbageWeeb Data 10 iunie 2022 16:48:02
Problema Subsecventa de suma maxima Scor 0
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.67 kb
#include <iostream>
#include <fstream>
#include <vector>
using namespace std;
ifstream in("ssm.in");
ofstream out("ssm.out");
int main()
{
	vector<int> v;
	int n,a,cur_sum,left=0,right=0,bleft,bright,bsum,ok=1;
	in >> n;
	for (int i = 0; i < n; i++)
	{
		in >> a;
		if (a >= 0)
		{
			ok = 1;
		}
		v.push_back(a);
	}
	bsum = cur_sum = v[0];
	while (left < n)
	{
		right++;
		if (right == n)
			break;
		cur_sum += v[right];
		if (cur_sum > bsum)
		{
			bsum = cur_sum;
			bleft = left;
			bright = right;
		}
		if (cur_sum < 0)
		{
			left = right + 1;
			cur_sum = 0;
		}
	}
	cout << bsum << " " << bleft +1<< " " << bright+1;

	return 0;
}