結果
| 問題 | No.2867 NOT FOUND 404 Again |
| コンテスト | |
| ユーザー |
回転
|
| 提出日時 | 2026-04-23 14:29:27 |
| 言語 | PyPy3 (7.3.17) |
| 結果 |
MLE
|
| 実行時間 | - |
| コード長 | 964 bytes |
| 記録 | |
| コンパイル時間 | 184 ms |
| コンパイル使用メモリ | 85,076 KB |
| 実行使用メモリ | 1,109,148 KB |
| 最終ジャッジ日時 | 2026-04-23 14:29:57 |
| 合計ジャッジ時間 | 7,223 ms |
|
ジャッジサーバーID (参考情報) |
judge3_1 / judge2_1 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 2 |
| other | AC * 1 MLE * 1 -- * 16 |
ソースコード
import pypyjit
pypyjit.set_param("max_unroll_recursion=-1")
import sys
sys.setrecursionlimit(10**7)
MOD = 998244353
S = input()
N = len(S)
memo = [[-1 for _ in range(6)] for _ in range(N)]
def f(n,ptr,giri):
if(ptr == 3):return 0
if(n == N):return 1
if(memo[n][(ptr<<1) + int(giri)] != -1):return memo[n][(ptr<<1) + int(giri)]
ret = 0
if(giri):
for i in range(int(S[n])):
next_ptr = ptr + 1 if int("404"[ptr]) == i else 1 if i == 4 else 0
ret += f(n+1,next_ptr,False)
ret %= MOD
next_ptr = ptr + 1 if int("404"[ptr]) == int(S[n]) else 1 if int(S[n]) == 4 else 0
ret += f(n+1,next_ptr,True)
ret %= MOD
else:
for i in range(10):
next_ptr = ptr + 1 if int("404"[ptr]) == i else 1 if i == 4 else 0
ret += f(n+1,next_ptr,False)
ret %= MOD
memo[n][(ptr<<1) + int(giri)] = ret
return ret
print((f(0,0,True) - 1) % MOD)
回転