Caso # | Resultado | Tiempo | Memoria |
---|---|---|---|
#1 |
Correcto
|
0.026 s | 3 KBi |
#2 |
Correcto
|
0.025 s | 3 KBi |
#3 |
Correcto
|
0.026 s | 3 KBi |
#4 |
Correcto
|
0.023 s | 3 KBi |
#5 |
Correcto
|
0.026 s | 3 KBi |
#6 |
Correcto
|
0.604 s | 44 KBi |
#7 |
Tiempo límite excedido
|
0.577 s | 43 KBi |
#8 |
Correcto
|
0.577 s | 58 KBi |
#9 |
Tiempo límite excedido
|
0.555 s | 37 KBi |
#10 |
Correcto
|
0.613 s | 61 KBi |
def sol(arr , N): frontier = [] result = [None] * N for idx in range(N-1, -1, -1): while(len(frontier) > 0 and arr[idx] >= frontier[-1]): _ = frontier.pop() if len(frontier) == 0: cover = -1 else: cover = frontier[-1] frontier.append(arr[idx]) result[idx] = cover return result num_cases = int(input()) str_results = [] for i in range(num_cases): N = int(input()) arr = [int(x) for x in input().split()] result = sol(arr, N) str_result = ' '.join([str(x) for x in result]) str_results.append(str_result) for i , str_result in enumerate(str_results): print(f"Case #{i+1}: {str_result}")