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

Envío 6168

Problema 0x94 - Subarreglo de máxima suma

Caso # Resultado Tiempo Memoria
#1
Correcto
0.003 s 0 KBi
#2
Correcto
0.01 s 1 KBi
#3
Correcto
0.001 s 0 KBi
#4
Correcto
0.002 s 0 KBi
#5
Correcto
0.006 s 65 KBi
#6
Correcto
0.002 s 0 KBi
#7
Correcto
0.001 s 0 KBi
#8
Correcto
0.002 s 0 KBi
#9
Correcto
0.002 s 0 KBi
#10
Correcto
0.002 s 0 KBi
#11
Correcto
0.002 s 0 KBi
#12
Correcto
0.011 s 1 KBi
#13
Correcto
0.002 s 0 KBi
#14
Correcto
0.002 s 0 KBi
#15
Correcto
0.002 s 0 KBi
#16
Correcto
0.002 s 0 KBi
#17
Incorrecto
0.023 s 2 KBi
#18
Correcto
0.025 s 2 KBi
#19
Correcto
0.026 s 2 KBi
#20
Incorrecto
0.014 s 1 KBi
#21
Incorrecto
0.008 s 1 KBi
#22
Incorrecto
0.018 s 1 KBi
#23
Correcto
0.008 s 1 KBi
#24
Correcto
0.01 s 1 KBi
Puntos totales: 84 / 100

Código

#include <bits/stdc++.h>
using namespace std;

int maxSumSubArr(int *arr, int l, int r){
    if(l >= r)
        return arr[l];
    int m = l + (r - l) / 2;
    long long sl = maxSumSubArr(arr, l, m);
    long long rl = maxSumSubArr(arr, m+1, r);
    long long best = max(sl, rl);

    long long bsl = arr[m];
    sl = arr[m];
    for(int i=m-1; i>=l; i--){
        sl += arr[i];
        bsl = max(bsl, sl);
    }

    long long bsr = arr[m+1];
    rl = arr[m+1];
    for(int i=m+2; i<=r; i++){
        rl += arr[i];
        bsr = max(bsr, rl);
    }

    return max(best, bsl+bsr);
}

int main() {
    ios_base::sync_with_stdio(false);
    cin.tie(NULL); 
    // your code goes here
    int n;
    cin >> n;
    int arr[n];
    for(int i=0;i<n;i++)
        cin >> arr[i];
    int best = maxSumSubArr(arr, 0, n-1);
    cout << best << endl;
	return 0;
}