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

Envío 4167

Problema 0x94 - Subarreglo de máxima suma

  • Autor: Serivt
  • Fecha: 2021-05-24 17:38:37 UTC (Hace casi 3 años)
Caso # Resultado Tiempo Memoria
#1
Incorrecto
0.03 s 3 KBi
#2
Incorrecto
0.025 s 3 KBi
#3
Incorrecto
0.029 s 3 KBi
#4
Incorrecto
0.024 s 4 KBi
#5
Incorrecto
0.022 s 3 KBi
#6
Incorrecto
0.02 s 3 KBi
#7
Incorrecto
0.018 s 3 KBi
#8
Incorrecto
0.021 s 3 KBi
#9
Incorrecto
0.029 s 3 KBi
#10
Incorrecto
0.016 s 3 KBi
#11
Incorrecto
0.028 s 3 KBi
#12
Incorrecto
0.023 s 3 KBi
#13
Incorrecto
0.02 s 3 KBi
#14
Incorrecto
0.018 s 3 KBi
#15
Incorrecto
0.026 s 3 KBi
#16
Incorrecto
0.036 s 3 KBi
#17
Incorrecto
0.622 s 12 KBi
#18
Incorrecto
0.579 s 11 KBi
#19
Incorrecto
0.584 s 12 KBi
#20
Incorrecto
0.595 s 12 KBi
#21
Incorrecto
0.933 s 12 KBi
#22
Incorrecto
0.618 s 11 KBi
#23
Incorrecto
0.548 s 11 KBi
#24
Incorrecto
0.604 s 11 KBi
Puntos totales: 0 / 100

Código

def get_max_sum_subarray(arr):
    length = len(arr)
    if length == 1:
        return arr[0]
    half = length // 2
    left = get_max_sum_subarray(arr[:half])
    right = get_max_sum_subarray(arr[half:])
    best = max(left, right)
    # middle
    best_left, sum_left = arr[half - 1], arr[half - 1]
    best_right, sum_right = arr[half], arr[half]
    for i in range(half - 2, -1, -1):
        sum_left += arr[i]
        best_left = max(best_left, sum_left)
    for i in range(half + 1, length):
        sum_right += arr[i]
        best_right = max(best_right, sum_right)
    return max(best, best_left + best_right)

n = int(input())
a = [int(i) for i in input().split()]
print(a)
print(get_max_sum_subarray(a))