結果
問題 | No.2703 FizzBuzz Letter Counting |
ユーザー |
👑 |
提出日時 | 2024-03-30 00:59:07 |
言語 | PyPy3 (7.3.15) |
結果 |
AC
|
実行時間 | 327 ms / 3,000 ms |
コード長 | 1,218 bytes |
コンパイル時間 | 350 ms |
コンパイル使用メモリ | 82,312 KB |
実行使用メモリ | 78,096 KB |
最終ジャッジ日時 | 2024-09-30 17:20:04 |
合計ジャッジ時間 | 13,112 ms |
ジャッジサーバーID (参考情報) |
judge2 / judge5 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 60 |
ソースコード
MOD = 998244353 m = int(input()) V = [0] * m L = [0] * m for i in range(m): V[i], L[i] = map(int, input().split()) n = sum(L) if n <= 2: S = "" for v, l in zip(V, L): S += str(v) * l ans = 0 for i in range(1, int(S) + 1): if i % 15 == 0: ans += 8 elif i % 3 == 0 or i % 5 == 0: ans += 4 else: ans += len(str(i)) print(ans) exit() inv9 = pow(9, -1, MOD) S = 96 S += 480 * ((pow(10, n - 3, MOD) - 1) * inv9 % MOD) S -= ((n - 1) * 48 % MOD) * pow(10, n - 2, MOD) S %= MOD S *= -inv9 S %= MOD S += 25 S -= 4 S += 192 * (pow(10, n - 2, MOD) - 1) * inv9 S %= MOD times = 0 for v, l in zip(V, L): times *= pow(10, l, MOD) times += v * (pow(10, l, MOD) - 1) * inv9 times %= MOD S += (times - pow(10, n - 1, MOD) + 1) * (n % MOD) % MOD S %= MOD d = times - pow(10, n - 1, MOD) f = V[-1] % 5 five = (d - f) * pow(5, -1, MOD) % MOD five += 1 S += five * (4 - n) t = sum(l * v for l, v in zip(L, V)) % 3 three = (d - t + 1) * pow(3, -1, MOD) % MOD S += three * (4 - n) x = 0 while x % 3 != t or x % 5 != f: x += 1 fifteen = (d - x + 10) * pow(15, -1, MOD) % MOD S += fifteen * n S %= MOD print(S % MOD)