結果
問題 |
No.2867 NOT FOUND 404 Again
|
ユーザー |
![]() |
提出日時 | 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)