結果

問題 No.3370 AB → BA
コンテスト
ユーザー n_bitand_n_per_3
提出日時 2025-11-18 00:08:32
言語 PyPy3
(7.3.15)
結果
WA  
実行時間 -
コード長 524 bytes
コンパイル時間 383 ms
コンパイル使用メモリ 82,732 KB
実行使用メモリ 149,800 KB
最終ジャッジ日時 2025-11-18 00:08:36
合計ジャッジ時間 3,807 ms
ジャッジサーバーID
(参考情報)
judge4 / judge1
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 1
other AC * 10 WA * 10
権限があれば一括ダウンロードができます

ソースコード

diff #

MOD = 998244353
U = 10**6
fact = [1]
for i in range(1,U+1):
    fact.append((fact[-1]*i)%MOD)
fact_inv = [-1]*(U+1)
fact_inv[U] = pow(fact[U],-1,MOD)
for i in range(U-1,-1,-1):
    fact_inv[i] = fact_inv[i+1]*(i+1)%MOD

#print(fact)
#print(fact_inv)

S = input()
N = len(S)
K = S.count("B")

def comb(x,y):
    if x < y:
        return 0
    return (((fact[x]*fact_inv[y])%MOD)*fact_inv[x-y])%MOD

ans = 1
for i in range(len(S)):
    if S[i] == "B":
        ans += comb(N-i-1,K)
        ans %= MOD
        K -= 1

print(ans)
0