結果
問題 |
No.2662 Installing Cell Towers
|
ユーザー |
|
提出日時 | 2024-03-16 14:29:33 |
言語 | PyPy3 (7.3.15) |
結果 |
AC
|
実行時間 | 149 ms / 2,000 ms |
コード長 | 573 bytes |
コンパイル時間 | 335 ms |
コンパイル使用メモリ | 82,432 KB |
実行使用メモリ | 86,972 KB |
最終ジャッジ日時 | 2024-09-30 03:59:05 |
合計ジャッジ時間 | 3,505 ms |
ジャッジサーバーID (参考情報) |
judge3 / judge1 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 18 |
ソースコード
n, m = map(int, input().split()) P = [0] * m Q = [0] * m for i in range(m): P[i], Q[i] = map(int, input().split()) A = [0] * (n + 10) for i in range(m): P[i] -= 1 l = P[i] - Q[i] r = P[i] + Q[i] l = max(l, 0) r = min(r, n) x = P[i] y = Q[i] - abs(x - l) A[l] += y A[l + 1] -= y - 1 A[x + 1] -= Q[i] + 1 A[x + 2] += Q[i] A[x + 1] += Q[i] - 1 A[x + 2] -= Q[i] y = Q[i] - abs(x - r) A[r + 1] += 1 for i in range(1, n + 10): A[i] += A[i - 1] for i in range(1, n + 10): A[i] += A[i - 1] print(*A[:n])