結果
| 問題 |
No.2867 NOT FOUND 404 Again
|
| コンテスト | |
| ユーザー |
detteiuu
|
| 提出日時 | 2024-08-30 23:16:36 |
| 言語 | PyPy3 (7.3.15) |
| 結果 |
TLE
|
| 実行時間 | - |
| コード長 | 1,569 bytes |
| コンパイル時間 | 307 ms |
| コンパイル使用メモリ | 82,424 KB |
| 実行使用メモリ | 85,684 KB |
| 最終ジャッジ日時 | 2024-08-30 23:16:41 |
| 合計ジャッジ時間 | 5,099 ms |
|
ジャッジサーバーID (参考情報) |
judge4 / judge5 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 2 |
| other | AC * 1 TLE * 1 -- * 16 |
ソースコード
N = input()
S = str(N)
L = len(S)
MOD = 998244353
dp = [[[[[0]*10 for _ in range(2)] for _ in range(2)] for _ in range(2)] for _ in range(2)]
dp[0][0][0][0][0] = 1
for i in range(L):
for zero in range(2):
for small in range(2):
for d in range(2):
for j in range(10):
if dp[0][zero][small][d][j] == 0:
continue
if zero == 0:
dp[1][zero][1][0][j] += dp[0][zero][small][0][j]
dp[1][zero][1][0][j] %= MOD
for k in range(1, 10 if small else int(S[i])+1):
dp[1][1][small or k<int(S[i])][0][k] += dp[0][zero][small][0][j]
dp[1][1][small or k<int(S[i])][0][k] %= MOD
continue
for k in range(10 if small else int(S[i])+1):
if d == 1 and k == 4:
continue
dp[1][1][small or k<int(S[i])][1 if j == 4 and k == 0 else 0][k] += dp[0][zero][small][d][j]
dp[1][1][small or k<int(S[i])][1 if j == 4 and k == 0 else 0][k] %= MOD
dp[0] = [[[k[:] for k in j[:]] for j in i[:]] for i in dp[1][:]]
for j in range(2):
for k in range(2):
for l in range(2):
for m in range(10):
dp[1][j][k][l][m] = 0
ans = 0
for i in range(2):
for j in range(2):
for k in range(10):
ans += dp[0][1][i][j][k]
ans %= MOD
print(ans)
detteiuu