█████████ ████ ███░░░░░███ ░░███ ███ ░░░ ██████ ███████ ██████ ██████ ░███ ███░░███ ███░░███ ███░░███ ███░░███ ░███ ░███ ░███░███ ░███ ░███████ ░███ ░███ ░░███ ███░███ ░███░███ ░███ ░███░░░ ░███ ░███ ░░█████████ ░░██████ ░░████████░░██████ ░░██████ ░░░░░░░░░ ░░░░░░ ░░░░░░░░ ░░░░░░ ░░░░░░

Envío 4100

Problema 0x94 - Subarreglo de máxima suma

  • Autor: pipelin1010
  • Fecha: 2021-05-14 15:13:18 UTC (Hace más de 3 años)
Caso # Resultado Tiempo Memoria
#1
Correcto
0.004 s 2 KBi
#2
Correcto
0.006 s 13 KBi
#3
Correcto
0.003 s 20 KBi
#4
Correcto
0.004 s 2 KBi
#5
Correcto
0.004 s 14 KBi
#6
Correcto
0.007 s 14 KBi
#7
Correcto
0.005 s 9 KBi
#8
Correcto
0.004 s 34 KBi
#9
Correcto
0.003 s 0 KBi
#10
Correcto
0.004 s 1 KBi
#11
Correcto
0.002 s 2 KBi
#12
Correcto
0.005 s 3 KBi
#13
Correcto
0.002 s 13 KBi
#14
Correcto
0.005 s 16 KBi
#15
Correcto
0.003 s 0 KBi
#16
Correcto
0.002 s 2 KBi
#17
Correcto
0.027 s 1 KBi
#18
Correcto
0.029 s 4 KBi
#19
Correcto
0.039 s 7 KBi
#20
Correcto
0.027 s 3 KBi
#21
Correcto
0.036 s 4 KBi
#22
Correcto
0.046 s 9 KBi
#23
Correcto
0.025 s 5 KBi
#24
Correcto
0.023 s 1 KBi
Puntos totales: 100 / 100

Código

//
#include <bits/stdc++.h>
using namespace std;
#define INF 1000000000
#define MOD 1000000007
#define PI 3.14159265
#define EPS 1e-9
#define Pi acos(-1.0)
typedef pair<int, int> ii;
typedef long long ll;
typedef vector<ll> vll;
typedef pair<ll,ll> pll;
#define forr(i,a,b) for(int i=(a); i<(b); i++)
#define clean(arr,val) memset(arr,val,sizeof(arr))
#define forn(i,n) forr(i,0,n)
#define PB push_back
typedef vector<int> vi;
typedef vector<ii> vii;
typedef vector<pll> vpll;

/*CODE START HERE*/

int n;
ll ans;
vi vec;

// // N^2
// void sol(){
//     ll aux = 0;
//     forn(i,n){
//         aux = 0;
//         forr(j,i,n){
//             aux += vec[j];
//             ans = max(aux,ans); 
//         }
//     }
// }

// n log n
ll solinMiddle(int l, int m, int r){
    ll sumL, sumR, aux;
    sumL = sumR = -INF;
    aux = 0;
    for(int i = m; i >= l; i--){
        aux += vec[i];
        sumL = max(aux,sumL);
    }
    aux = 0;
    for(int i = m+1; i <= r; i++){
        aux += vec[i];
        sumR = max(sumR, aux);
    }
    //cout << "SOL IN MIDDE FOR " << l << " " << m << " " << r << " = " << max(sumR, max(sumL, sumR+sumL)) << "\n";
    return sumR+sumL;
} 

ll sol(int l, int r){
    //cout << "NOW ON " << l << " " << r << "\n";
    if(l == r){
        return vec[l];
    }
    int m = (l+r)/2;
    return max(sol(l,m),max(solinMiddle(l,m,r),sol(m+1,r)));  
}

int main(){
    ios::sync_with_stdio(0);
    cin >> n;
    vec.assign(n,0);
    forn(i,n){
        cin >> vec[i];
    }
    ans = -INF;
    ans = sol(0, n-1); // sol n log n
    cout << ans << "\n";
    return 0;
}