結果
問題 | No.2359 A in S ? |
ユーザー |
![]() |
提出日時 | 2023-06-27 22:11:04 |
言語 | PyPy3 (7.3.15) |
結果 |
AC
|
実行時間 | 590 ms / 2,000 ms |
コード長 | 760 bytes |
コンパイル時間 | 915 ms |
コンパイル使用メモリ | 82,428 KB |
実行使用メモリ | 129,476 KB |
最終ジャッジ日時 | 2024-07-04 14:41:20 |
合計ジャッジ時間 | 6,173 ms |
ジャッジサーバーID (参考情報) |
judge5 / judge2 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 2 |
other | AC * 18 |
ソースコード
N, M = map(int, input().split()) LRXY = [list(map(int, input().split())) for _ in range(N)] A = list(map(int, input().split())) maxa = max(A) from collections import defaultdict dic = defaultdict(list) for i, (l, r, x, y) in enumerate(LRXY): if maxa < r: LRXY[i][1] = maxa r = maxa dic[(x, y)].append((l, r)) maxa = max(maxa, y) ans = [0] * (maxa + 1) for k, v in dic.items(): x, y = k n = maxa // x + 2 imost = [0] * (n + 1) for l, r in v: L = - ((y - l) // x) R = (r - y) // x imost[L] += 1 imost[R + 1] -= 1 for i in range(n - 1): tmp = imost[i] imost[i + 1] += tmp if i * x + y <= maxa: ans[i * x + y] += tmp for a in A: print(ans[a])