Cod sursa(job #3218442)

Utilizator YuzukyIstrate Andreea Ruxandra Yuzuky Data 27 martie 2024 11:09:44
Problema Subsecventa de suma maxima Scor 95
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.88 kb
#include <iostream>
#include <fstream>
using namespace std;
ifstream in("ssm.in");
ofstream out("ssm.out");
const int MAX = 6000000;
int s[MAX+1], best[MAX+1];
int main()
{
    int n;
    in>>n;
    for(int i=0; i<n; ++i)
        in>>s[i];
    for(int i=1; i<n; ++i)
        s[i]=s[i]+s[i-1];

   // cout<<"sume partiale "<<'\n';
    //for(int i=0; i<n; ++i)
        //cout<<s[i]<<" ";
    int minim=min(s[0],0);
    int bestsum=s[0], poz1=0, poz2=0, st_ans=0;
    for(int i=1; i<n; ++i)
    {
        best[i]=s[i]-minim;
        cout<<best[i]<<" ";
        if(minim>s[i])
        {
            minim=s[i];
            poz1=i+1;
        }
        if(bestsum<best[i])
        {
            bestsum=best[i];
            st_ans=poz1;
            poz2=i;
        }
    }
    out<<bestsum<<" "<<st_ans+1<<" "<<poz2+1; //eu incep cu vectorul de la 0
    return 0;
}