結果

問題 No.2325 Skill Tree
コンテスト
ユーザー 👑 SPD_9X2
提出日時 2023-05-28 15:28:50
言語 PyPy3
(7.3.17)
コンパイル:
pypy3 -mpy_compile _filename_
実行:
pypy3 _filename_
結果
AC  
実行時間 328 ms / 3,000 ms
コード長 753 bytes
記録
記録タグの例:
初AC ショートコード 純ショートコード 純主流ショートコード 最速実行時間
コンパイル時間 369 ms
コンパイル使用メモリ 84,992 KB
実行使用メモリ 122,232 KB
最終ジャッジ日時 2026-06-01 22:59:50
合計ジャッジ時間 12,239 ms
ジャッジサーバーID
(参考情報)
judge3_1 / judge2_0
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 2
other AC * 36
権限があれば一括ダウンロードができます

ソースコード

diff #
raw source code

from sys import stdin
import bisect
from collections import deque

N = int(stdin.readline())

L = [0] + [float("inf")] * (N-1)

lis = [ [] for i in range(N) ]

for i in range(N-1):

    l,a = map(int,stdin.readline().split())
    a -= 1
    lis[a].append( (i+1,l) )

q = deque([0])
while q:
    v = q.popleft()
    for nex,cost in lis[v]:
        L[nex] = max(L[v] , cost)
        q.append(nex)

L2 = [i for i in L]
L2.sort()

Q = int(stdin.readline())

ANS = []
for loop in range(Q):

    ty,x = map(int,stdin.readline().split())

    if ty == 1:
        idx = bisect.bisect_right(L2,x)
        ANS.append(idx)
    else:
        if L[x-1] == float("inf"):
            ANS.append(-1)
        else:
            ANS.append(L[x-1])

print (*ANS,sep="\n")
0