結果
| 問題 | No.2867 NOT FOUND 404 Again |
| コンテスト | |
| ユーザー |
回転
|
| 提出日時 | 2026-04-23 14:33:02 |
| 言語 | Python3 (3.14.3 + numpy 2.4.4 + scipy 1.17.1) |
| 結果 |
TLE
|
| 実行時間 | - |
| コード長 | 909 bytes |
| 記録 | |
| コンパイル時間 | 485 ms |
| コンパイル使用メモリ | 20,952 KB |
| 実行使用メモリ | 417,820 KB |
| 最終ジャッジ日時 | 2026-04-23 14:33:26 |
| 合計ジャッジ時間 | 5,829 ms |
|
ジャッジサーバーID (参考情報) |
judge3_0 / judge1_1 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 2 |
| other | AC * 1 TLE * 1 -- * 16 |
ソースコード
import sys
sys.setrecursionlimit(10**6 + 10)
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)
回転