Cod sursa(job #458900)

Utilizator liviu12345Stoica Liviu liviu12345 Data 26 mai 2010 21:08:47
Problema Subsecventa de suma maxima Scor 95
Compilator cpp Status done
Runda Arhiva educationala Marime 0.79 kb
#include <iostream>
#include <fstream>

const int MAXN = 6e+6 ;

using namespace std ;

ifstream f ( "ssm.in" ) ;
ofstream g ( "ssm.out" ) ;

int secventa [ MAXN ] ;
long suma [ MAXN ] ;
int nrNumere , maximum , Start = 1 ;

int maxEu ( int a , int b )
{
  if ( a > b )
    return a ;
  return b ;
}

void citireFisier ( ) 
{
  f >> nrNumere ;
  int Start1 = 1 ;
  for ( int i = 1 ; i <= nrNumere ; i++ )
  {
    f >> secventa [ i ] ;
    if ( suma [ i - 1 ] < 0 )
      Start1 = i ;
    suma [ i ] = maxEu ( 0 , suma [ i - 1 ] ) ;
    suma [ i ] += secventa [ i ] ;
    if ( suma [ maximum ] < suma [ i ] )
    {
      Start = Start1 ;
      maximum = i ;
    }
  }
}

int main ( )
{
  citireFisier ( ) ;
  int S ;
  g << suma [ maximum ] << " " ;
  g << Start << " " << maximum << endl ;
  return 0 ;
}