結果

問題 No.1646 Avoid Palindrome
コンテスト
ユーザー 回転
提出日時 2026-01-13 16:17:17
言語 PyPy3
(7.3.17)
結果
TLE  
実行時間 -
コード長 578 bytes
記録
記録タグの例:
初AC ショートコード 純ショートコード 純主流ショートコード 最速実行時間
コンパイル時間 277 ms
コンパイル使用メモリ 82,260 KB
実行使用メモリ 235,712 KB
最終ジャッジ日時 2026-01-13 16:17:24
合計ジャッジ時間 5,931 ms
ジャッジサーバーID
(参考情報)
judge2 / judge1
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 4
other TLE * 1 -- * 39
権限があれば一括ダウンロードができます

ソースコード

diff #
raw source code

import pypyjit
pypyjit.set_param("max_unroll_recursion=-1")
import sys
sys.setrecursionlimit(10**7)

from functools import cache
MOD = 998244353
N = int(input())
S = input()

@cache
def f(n,p,pp):
    if(n == N):return 1

    ret = 0
    if(S[n] == "?"):
        p_ord = ord(p) - 97
        pp_ord = ord(pp) - 97
        for i in range(26):
            if(p_ord == i or pp_ord == i):continue
            ret += f(n+1, chr(i + 97), p)
            ret %= MOD
    else:
        if(p == S[n] or pp == S[n]):return 0
        ret += f(n+1, S[n], p)
    return ret

print(f(0,"@","@"))
0