結果
問題 | No.2568 列辞書順列列 |
ユーザー | torippy |
提出日時 | 2023-12-02 16:34:41 |
言語 | PyPy3 (7.3.15) |
結果 |
AC
|
実行時間 | 379 ms / 3,000 ms |
コード長 | 525 bytes |
コンパイル時間 | 139 ms |
コンパイル使用メモリ | 82,644 KB |
実行使用メモリ | 120,164 KB |
最終ジャッジ日時 | 2024-09-26 20:27:42 |
合計ジャッジ時間 | 11,012 ms |
ジャッジサーバーID (参考情報) |
judge3 / judge4 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 2 |
other | AC * 25 |
ソースコード
N, M, Q = map(int, input().split()) A = list(map(int, input().split())) MOD = 998244353 ls = [] rs = [] invs = [] p = 1 for i in range(N+1): invs.append(pow(p, MOD-2, MOD)) p = (p*M) % MOD for _ in range(Q): l, r = map(int, input().split()) ls.append(l) rs.append(r) acc = [0] p = 1 for i in range(N): acc.append((acc[-1] + (A[N-i-1]-1)*p) % MOD) p = (p*M) % MOD for i in range(Q): l, r, = ls[i], rs[i] r = N-r l = N-l+1 ans = ((acc[l]-acc[r])*invs[r]+1) % MOD print(ans)