結果
問題 |
No.1950 片道きゃっちぼーる
|
ユーザー |
![]() |
提出日時 | 2022-05-21 23:34:43 |
言語 | Python3 (3.13.1 + numpy 2.2.1 + scipy 1.14.1) |
結果 |
WA
|
実行時間 | - |
コード長 | 652 bytes |
コンパイル時間 | 186 ms |
コンパイル使用メモリ | 12,672 KB |
実行使用メモリ | 189,544 KB |
最終ジャッジ日時 | 2024-09-20 12:12:58 |
合計ジャッジ時間 | 32,095 ms |
ジャッジサーバーID (参考情報) |
judge2 / judge5 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
other | AC * 16 WA * 7 |
ソースコード
from sys import setrecursionlimit setrecursionlimit(10**6) from collections import defaultdict def dfs(pos): if Dic[pos]: return Dic[pos] Flg[pos] = True ret = pos for nxt in G[pos]: if Flg[nxt]: continue ret = max(ret, dfs(nxt)) Flg[pos] = False Dic[pos] = ret return ret N = int(input()) X = list(map(int,input().split())) A = list(map(int,input().split())) G = defaultdict(list) for i in range(N): if X[i] - A[i] >= 0: G[X[i]].append(X[i] - A[i]) G[X[i]].append(X[i] + A[i]) Flg = defaultdict(int) Dic = defaultdict(int) for i in range(N): print(dfs(X[i]) - X[i])