結果

問題 No.1637 Easy Tree Query
ユーザー harurunharurun
提出日時 2021-06-19 00:49:40
言語 Python3
(3.12.2 + numpy 1.26.4 + scipy 1.12.0)
結果
AC  
実行時間 1,099 ms / 2,000 ms
コード長 2,280 bytes
コンパイル時間 84 ms
コンパイル使用メモリ 12,800 KB
実行使用メモリ 49,704 KB
最終ジャッジ日時 2024-09-17 03:17:47
合計ジャッジ時間 22,574 ms
ジャッジサーバーID
(参考情報)
judge2 / judge5
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 AC 33 ms
10,752 KB
testcase_01 AC 30 ms
10,624 KB
testcase_02 AC 1,018 ms
29,388 KB
testcase_03 AC 30 ms
10,752 KB
testcase_04 AC 308 ms
19,944 KB
testcase_05 AC 800 ms
18,136 KB
testcase_06 AC 528 ms
16,072 KB
testcase_07 AC 279 ms
11,264 KB
testcase_08 AC 255 ms
17,884 KB
testcase_09 AC 701 ms
24,828 KB
testcase_10 AC 373 ms
14,848 KB
testcase_11 AC 914 ms
26,420 KB
testcase_12 AC 879 ms
22,908 KB
testcase_13 AC 180 ms
14,848 KB
testcase_14 AC 504 ms
24,700 KB
testcase_15 AC 883 ms
26,928 KB
testcase_16 AC 715 ms
28,484 KB
testcase_17 AC 282 ms
14,976 KB
testcase_18 AC 736 ms
17,896 KB
testcase_19 AC 753 ms
19,448 KB
testcase_20 AC 915 ms
22,648 KB
testcase_21 AC 503 ms
20,464 KB
testcase_22 AC 1,010 ms
29,140 KB
testcase_23 AC 272 ms
15,744 KB
testcase_24 AC 422 ms
20,316 KB
testcase_25 AC 813 ms
17,560 KB
testcase_26 AC 933 ms
23,672 KB
testcase_27 AC 1,099 ms
28,576 KB
testcase_28 AC 581 ms
16,756 KB
testcase_29 AC 739 ms
22,032 KB
testcase_30 AC 324 ms
21,240 KB
testcase_31 AC 614 ms
11,392 KB
testcase_32 AC 407 ms
17,268 KB
testcase_33 AC 749 ms
15,464 KB
testcase_34 AC 446 ms
49,704 KB
権限があれば一括ダウンロードができます

ソースコード

diff #

# class INPUT:
#   def __init__(self):
#     self._l=open(0).read().split()
#     self._length=len(self._l)
#     self._index=0
#     return

#   def stream(self,k=1,f=int,f2=False):
#     assert(-1<k)
#     if self._length==self._index or self._length-self._index<k:
#       raise Exception("There is no input!")
#     elif f!=str:
#       if k==0:
#         ret=list(map(f,self._l[self._index:]))
#         self._index=self._length
#         return ret
#       if k==1 and not f2:
#         ret=f(self._l[self._index])
#         self._index+=1
#         return ret
#       if k==1 and f2:
#         ret=[f(self._l[self._index])]
#         self._index+=1
#         return ret
#       ret=[]
#       for _ in [0]*k:
#         ret.append(f(self._l[self._index]))
#         self._index+=1
#       return ret
#     else:
#       if k==0:
#         ret=list(self._l[self._index:])
#         self._index=self._length
#         return ret
#       if k==1 and not f2:
#         ret=self._l[self._index]
#         self._index+=1
#         return ret
#       if k==1 and f2:
#         ret=[self._l[self._index]]
#         self._index+=1
#         return ret
#       ret=[]
#       for _ in [0]*k:
#         ret.append(self._l[self._index])
#         self._index+=1
#       return ret
# pin=INPUT().stream

# """
# pin(number[default:1],f[default:int],f2[default:False])
# if number==0 -> return left all
# listを変数で受け取るとき、必ずlistをTrueにすること。
# """
from sys import setrecursionlimit
from collections import deque
setrecursionlimit(10000000)
def main():
  #N,Q=pin(2)
  N,Q=map(int,input().split())
  assert(2<=N<=10**5)
  assert(1<=Q<=10**5)
  d=[[]for _ in[0]*N]
  for _ in[0]*(N-1):
    #a,b=pin(2)
    a,b=map(int,input().split())
    assert(1<=a<=N)
    assert(1<=b<=N)
    d[a-1].append(b-1)
    d[b-1].append(a-1)
  cnt=[1]*N
  B=[0]*N
  def f(i):
    B[i]=1
    for j in d[i]:
      if B[j]==0:
        f(j)
        cnt[i]+=cnt[j]
    return 
  f(0)
  ans=0
  for _ in[0]*Q:
    #p,x=pin(2)
    p,x=map(int,input().split())
    assert(1<=p<=N)
    assert(1<=x<=10**8)
    ans+=cnt[p-1]*x
    print(ans)
  # is_input=False
  # try:
  #   input()
  #   is_input=True
  # except:
  #   pass
  # if is_input:
  #   raise Exception
  # return

main()
0