結果
| 問題 | 
                            No.1864 Shortest Paths Counting
                             | 
                    
| コンテスト | |
| ユーザー | 
                             | 
                    
| 提出日時 | 2022-03-01 21:52:50 | 
| 言語 | Python3  (3.13.1 + numpy 2.2.1 + scipy 1.14.1)  | 
                    
| 結果 | 
                             
                                AC
                                 
                             
                            
                         | 
                    
| 実行時間 | 1,688 ms / 2,000 ms | 
| コード長 | 1,306 bytes | 
| コンパイル時間 | 267 ms | 
| コンパイル使用メモリ | 12,800 KB | 
| 実行使用メモリ | 59,024 KB | 
| 最終ジャッジ日時 | 2024-07-16 13:20:39 | 
| 合計ジャッジ時間 | 22,287 ms | 
| 
                            ジャッジサーバーID (参考情報)  | 
                        judge1 / judge2 | 
(要ログイン)
| ファイルパターン | 結果 | 
|---|---|
| sample | AC * 4 | 
| other | AC * 23 | 
ソースコード
def main():
  mod = 998244353
  # mod 998244353のFenwickTree
  class FenwickTreeMod:
    def __init__(self, n):
      self.n = n
      self.data = [0] * (n + 1)
    def add(self, k, x):
      k += 1
      while k <= self.n:
        self.data[k] += x
        self.data[k] %= mod
        k += k & -k
    def sum(self, k):
      res = 0
      while k:
        res += self.data[k]
        res %= mod
        k -= k & -k
      return res
  # 座標圧縮
  def compress(a):
    mem = {}
    for idx, elm in enumerate(sorted(set(a))):
      mem[elm] = idx
    return mem
  # 入力
  N = int(input())
  X, Y = [None] * N, [None] * N
  for i in range(N):
    a, b = map(int, input().split())
    X[i], Y[i] = a + b, a - b
  # 座標を反転しておく
  if X[0] > X[-1]:
    for i in range(N):
      X[i] = -X[i]
  if Y[0] > Y[-1]:
    for i in range(N):
      Y[i] = -Y[i]
  
  # y座標を圧縮
  mem = compress(Y)
  for i in range(N):
    Y[i] = mem[Y[i]]
  
  # x, y座標が範囲内の点のみソート
  points = [(i, j) for i, j in zip(X, Y) if X[0] <= i <= X[-1] and Y[0] <= j <= Y[-1]]
  points.sort()
  # DP
  ft = FenwickTreeMod(len(mem))
  ft.add(Y[0], 1)
  for i in range(1, len(points) - 1):
    ft.add(points[i][1], ft.sum(points[i][1] + 1))
  # 出力
  print(ft.sum(Y[-1] + 1))
main()