結果
| 問題 | No.1997 X Lighting | 
| コンテスト | |
| ユーザー |  MasKoaTS | 
| 提出日時 | 2022-04-23 15:10:30 | 
| 言語 | Python3 (3.13.1 + numpy 2.2.1 + scipy 1.14.1) | 
| 結果 | 
                                AC
                                 
                             | 
| 実行時間 | 774 ms / 2,000 ms | 
| コード長 | 725 bytes | 
| コンパイル時間 | 224 ms | 
| コンパイル使用メモリ | 12,672 KB | 
| 実行使用メモリ | 32,816 KB | 
| 最終ジャッジ日時 | 2024-06-25 02:13:55 | 
| 合計ジャッジ時間 | 12,884 ms | 
| ジャッジサーバーID (参考情報) | judge2 / judge1 | 
(要ログイン)
| ファイルパターン | 結果 | 
|---|---|
| sample | AC * 3 | 
| other | AC * 30 | 
ソースコード
from bisect import bisect_left, bisect_right from collections import deque import sys input = sys.stdin.readline n, m = map(int, input().split()) xst = set([]); yst = set([]) for _ in [0] * m: X, Y = map(int, input().split()) xst.add((X - 1) + (Y - 1)) yst.add((X - 1) - (Y - 1)) ans = 0 xlis = [[] for _ in [0] * 2] for x in xst: ans += min(x, n - 1) - max(-n + 1 + x, 0) + 1 xlis[x & 1].append(x) for y in yst: ans += min(n - 1 + y, n - 1) - max(y, 0) + 1 que = [deque(sorted(lis)) for lis in xlis] for y in sorted(abs(y) for y in yst): lv, rv = y, 2 * (n - 1) - y b = y & 1 while(que[b] and que[b][-1] > rv): que[b].pop() while(que[b] and que[b][0] < lv): que[b].popleft() ans -= len(que[b]) print(ans)
