結果
問題 |
No.3089 Base M Numbers, But Only 0~9
|
ユーザー |
![]() |
提出日時 | 2025-04-04 22:31:08 |
言語 | PyPy3 (7.3.15) |
結果 |
WA
|
実行時間 | - |
コード長 | 1,124 bytes |
コンパイル時間 | 392 ms |
コンパイル使用メモリ | 82,596 KB |
実行使用メモリ | 103,572 KB |
最終ジャッジ日時 | 2025-04-04 22:31:25 |
合計ジャッジ時間 | 5,650 ms |
ジャッジサーバーID (参考情報) |
judge3 / judge5 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 5 |
other | AC * 13 WA * 6 |
ソースコード
class Inv: def __init__(s, mod): s.MOD = mod def modpow(s, a, n): res = 1 while n > 0: if n & 1: res = res * a % s.MOD a = a * a % s.MOD n >>= 1 return res def invx(s, a): return s.modpow(a, s.MOD - 2) def invpowL(s, a, n): # a^-x (0 <= x <= n)リスト ia = s.invx(a) L = [1] * (n + 1) for i in range(1, n + 1): L[i] = L[i - 1] * ia % s.MOD return L def invL(s, n): # 0 <= x <= n 逆元リスト I = [0, 1] for i in range(2, n + 1): I.append(s.MOD - I[s.MOD % i] * (s.MOD // i) % s.MOD) return I def yu(a, e, c): return ((a + e) * c // 2) % MOD M = int(input()) N = input() MOD = 998244353 D = [0] * 10 C = [0] * 10 for i in range(10): C[i] = M // 10 if i < M % 10: C[i] += 1 D[i] = yu(i, i + 10 * (C[i] - 1), C[i]) t = 1 L = [] CL = [] for a in N[::-1]: n = int(a) L.append(t * D[n] % MOD) CL.append(C[n]) t *= M t %= MOD k = 1 for c in CL: k *= c k %= MOD inv = Inv(MOD) ans = 0 for i in range(len(L)): x = L[i] c = k * inv.invx(CL[i]) % MOD ans += x * c % MOD ans %= MOD print(ans % MOD)