結果
問題 |
No.2568 列辞書順列列
|
ユーザー |
![]() |
提出日時 | 2024-11-29 00:09:04 |
言語 | PyPy3 (7.3.15) |
結果 |
AC
|
実行時間 | 376 ms / 3,000 ms |
コード長 | 550 bytes |
コンパイル時間 | 395 ms |
コンパイル使用メモリ | 82,100 KB |
実行使用メモリ | 123,908 KB |
最終ジャッジ日時 | 2024-11-29 00:09:18 |
合計ジャッジ時間 | 12,288 ms |
ジャッジサーバーID (参考情報) |
judge5 / judge2 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 2 |
other | AC * 25 |
ソースコード
N, M, Q = map(int, input().split()) A = list(map(int, input().split())) LR = [list(map(int, input().split())) for _ in range(Q)] MOD = 998244353 B = [] for i in range(N): B.append(A[i]-1) POW = [1] POW_inv = [1] for _ in range(N): POW.append(POW[-1]*M%MOD) POW_inv.append(pow(POW[-1], -1, MOD)) for i in reversed(range(N)): B[i] *= POW[N-1-i] B[i] %= MOD cum = [0] for i in range(N): cum.append((cum[-1]+B[i])%MOD) for L, R in LR: L -= 1 q = (cum[R]-cum[L])%MOD ans = q*POW_inv[N-R]%MOD print((ans+1)%MOD)