92292024-02-19 08:33:37KezdőBináris fa magassága (50 pont)python3Időlimit túllépés 40/50522ms16412 KiB
from sys import stdin,stdout

def main():
    N,M = [int(i) for i in stdin.readline().split()]
    a = [N]   # alatta levő "mélység"
    k = 1
    for i in range(1,N+1):
        a = a + [N-i]*k
        k *= 2
    h = [1]*k

    for i in range(M):
        cs,x = [int(i) for i in stdin.readline().split()]
        h[cs] = x
        while cs > 1:
            c = cs//2
            c2 = c*2
            a[c] = max(h[c2]+a[c2], h[c2+1]+a[c2+1])
            cs = c
        print(a[1])

main()
RészfeladatÖsszpontTesztVerdiktIdőMemória
base40/50
1Elfogadva0/017ms11060 KiB
2Elfogadva0/0331ms14116 KiB
3Elfogadva2/219ms12132 KiB
4Elfogadva2/219ms12168 KiB
5Elfogadva2/219ms12212 KiB
6Elfogadva2/220ms12244 KiB
7Elfogadva3/320ms12396 KiB
8Elfogadva3/320ms12548 KiB
9Elfogadva3/323ms12868 KiB
10Elfogadva3/323ms13080 KiB
11Időlimit túllépés0/2522ms15440 KiB
12Időlimit túllépés0/2518ms15812 KiB
13Időlimit túllépés0/2518ms15800 KiB
14Időlimit túllépés0/2521ms15756 KiB
15Időlimit túllépés0/2521ms16036 KiB
16Elfogadva2/2333ms15872 KiB
17Elfogadva2/2337ms16000 KiB
18Elfogadva2/2335ms16324 KiB
19Elfogadva2/2335ms16260 KiB
20Elfogadva3/3368ms16412 KiB
21Elfogadva3/3368ms16376 KiB
22Elfogadva3/3370ms16192 KiB
23Elfogadva3/3363ms16304 KiB