結果
問題 | No.2923 Mayor's Job |
ユーザー |
![]() |
提出日時 | 2024-10-12 14:55:20 |
言語 | PyPy3 (7.3.15) |
結果 |
WA
|
実行時間 | - |
コード長 | 748 bytes |
コンパイル時間 | 171 ms |
コンパイル使用メモリ | 82,160 KB |
実行使用メモリ | 78,376 KB |
最終ジャッジ日時 | 2024-10-12 14:55:30 |
合計ジャッジ時間 | 2,849 ms |
ジャッジサーバーID (参考情報) |
judge1 / judge |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 1 WA * 16 |
ソースコード
from collections import deque N, K = map(int, input().split()) H = list(map(int, input().split())) XY = [list(map(int, input().split())) for _ in range(N)] K **= 2 def distance(x1, y1, x2, y2): return (x2-x1)**2 + (y2-y1)**2 H = sorted([(i, H[i]) for i in range(N)], key=lambda x:x[1], reverse=True) ans = 0 visited = [False]*N for idx, h in H: if visited[idx]: continue ans += 1 visited[idx] = True que = deque() que.append(idx) while que: n = que.popleft() X1, Y1 = XY[n] for i in range(N): X2, Y2 = XY[i] if not visited[i] and H[idx][1] > H[i][1] and distance(X1, Y1, X2, Y2) <= K: visited[i] = True que.append(i) print(ans)