結果
問題 | No.2439 Fragile Apple Tree |
ユーザー | tatyam |
提出日時 | 2023-08-18 18:24:10 |
言語 | PyPy3 (7.3.15) |
結果 |
TLE
|
実行時間 | - |
コード長 | 3,255 bytes |
コンパイル時間 | 210 ms |
コンパイル使用メモリ | 82,048 KB |
実行使用メモリ | 634,332 KB |
最終ジャッジ日時 | 2024-11-28 02:12:58 |
合計ジャッジ時間 | 220,904 ms |
ジャッジサーバーID (参考情報) |
judge1 / judge2 |
(要ログイン)
テストケース
テストケース表示入力 | 結果 | 実行時間 実行使用メモリ |
---|---|---|
testcase_00 | TLE | - |
testcase_01 | TLE | - |
testcase_02 | TLE | - |
testcase_03 | MLE | - |
testcase_04 | MLE | - |
testcase_05 | TLE | - |
testcase_06 | TLE | - |
testcase_07 | TLE | - |
testcase_08 | TLE | - |
testcase_09 | AC | 51 ms
263,180 KB |
testcase_10 | AC | 54 ms
69,120 KB |
testcase_11 | AC | 50 ms
69,376 KB |
testcase_12 | AC | 52 ms
69,376 KB |
testcase_13 | AC | 51 ms
69,888 KB |
testcase_14 | TLE | - |
testcase_15 | TLE | - |
testcase_16 | TLE | - |
testcase_17 | TLE | - |
testcase_18 | AC | 7,363 ms
176,908 KB |
testcase_19 | AC | 6,473 ms
141,420 KB |
testcase_20 | AC | 3,258 ms
128,000 KB |
testcase_21 | AC | 1,072 ms
98,176 KB |
testcase_22 | AC | 9,835 ms
156,528 KB |
testcase_23 | AC | 4,902 ms
122,624 KB |
testcase_24 | AC | 5,748 ms
136,576 KB |
testcase_25 | AC | 5,332 ms
158,628 KB |
testcase_26 | AC | 6,282 ms
169,744 KB |
testcase_27 | AC | 4,715 ms
141,824 KB |
testcase_28 | AC | 50 ms
69,376 KB |
testcase_29 | AC | 52 ms
68,608 KB |
testcase_30 | AC | 55 ms
74,880 KB |
testcase_31 | AC | 5,878 ms
191,076 KB |
testcase_32 | MLE | - |
ソースコード
# パス減算 → 破壊チェック → 破壊された辺に掛かっていた重みを上にパス加算 # 必要な操作: 辺属性, パス加算, 区間 min の max-right, 1 辺取得 import sys import pypyjit pypyjit.set_param('max_unroll_recursion=0') sys.setrecursionlimit(2 ** 20) input = sys.stdin.readline INF = 1 << 61 SIZ = 1 << 19 LOG = 19 d = [INF] * (SIZ * 2) lz = [0] * (SIZ * 2) def all_apply(k: int, f: int): d[k] += f lz[k] += f def push(k: int): if lz[k]: all_apply(2 * k, lz[k]) all_apply(2 * k + 1, lz[k]) lz[k] = 0 def update(k: int): d[k] = min(d[k << 1], d[k << 1 | 1]) def get(p: int): p += SIZ for i in range(LOG, 0, -1): push(p >> i) return d[p] def add(l: int, r: int, x: int): if l == r: return l += SIZ r += SIZ for i in range(LOG, 0, -1): if l >> i << i != l: push(l >> i) if r >> i << i != r: push((r - 1) >> i) def F(l: int, r: int): while l < r: if l & 1: all_apply(l, x) l += 1 if r & 1: r -= 1 all_apply(r, x) l >>= 1 r >>= 1 F(l, r) for i in range(1, LOG + 1): if l >> i << i != l: update(l >> i) if r >> i << i != r: update((r - 1) >> i) def broken_edge() -> int: r = 2 for _ in range(LOG): push(r - 1) r <<= 1 if d[r - 1] > 0: r -= 1 return r - SIZ - 1 N, Q = map(int, input().split()) edge: list[list[int]] = [list(map(int, input().split())) for _ in range(N - 1)] g: list[list[int]] = [[] for _ in range(N)] for e in edge: e[0] -= 1 e[1] -= 1 a, b, c = e g[a].append(b) g[b].append(a) siz = [1] * N parent = [-1] * N C = [0] * N q = [0] for i in q: for j in g[i]: parent[j] = i q.append(j) g[j].remove(i) for i in reversed(q): p = parent[i] if p != -1: siz[p] += siz[i] if g[i]: j = max(g[i], key=lambda x: siz[x]) g[i].remove(j) g[i].insert(0, j) C[0] = INF for a, b, c in edge: a = min(a, b, key=lambda x: siz[x]) C[a] = c heavy = [0] * N index = [0] * N idx = 0 def dfs(i: int): global idx index[i] = idx add(idx, idx + 1, C[i] - INF) idx += 1 if not g[i]: return heavy[g[i][0]] = heavy[i] dfs(g[i][0]) for j in g[i][1:]: heavy[j] = j dfs(j) dfs(0) rev = [-1] * N for i in range(N): rev[index[i]] = i vertices = N erased = [False] * N def path_add(i: int, x: int): while i > 0: h = heavy[i] add(index[h], index[i] + 1, x) i = parent[h] def dfs(i: int): global vertices if erased[i]: return erased[i] = True vertices -= 1 x = C[i] - get(index[i]) add(index[i], index[i] + 1, INF) for j in g[i]: dfs(j) for _ in range(Q): query = input() if query[0] == '1': v, x = map(int, query[2:].split()) v -= 1 # 0 - v パスに x を減算 path_add(v, -x) # <= 0 の辺を切る while d[1] <= 0: i = rev[broken_edge()] path_add(i, C[i] - get(index[i])) dfs(i) else: print(vertices)