結果

問題 No.1958 Bit Game
コンテスト
ユーザー ntuda
提出日時 2025-12-02 21:19:07
言語 PyPy3
(7.3.15)
結果
AC  
実行時間 368 ms / 2,000 ms
コード長 766 bytes
記録
記録タグの例:
初AC ショートコード 純ショートコード 純主流ショートコード 最速実行時間
コンパイル時間 398 ms
コンパイル使用メモリ 82,348 KB
実行使用メモリ 144,104 KB
最終ジャッジ日時 2025-12-02 21:19:18
合計ジャッジ時間 9,884 ms
ジャッジサーバーID
(参考情報)
judge3 / judge1
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 3
other AC * 30
権限があれば一括ダウンロードができます

ソースコード

diff #
raw source code

MOD = 998244353
N,X,Y = map(int,input().split())
XY = [X,Y]
AB = [list(map(int,input().split())) for _ in range(2)]
CD = [[0] * 18 for _ in range(2)]

for i in range(2):
    for a in AB[i]:
        for j in range(18):
            if a & 1:
                CD[i][j] += 1
            a >>= 1
            if a == 0:
                break
E = [0] * 18
E2 = [0] * 18

cnt = 1
for i in range(N):
    cnt2 = (cnt * XY[0]) % MOD
    for j in range(18):
        E2[j] = E[j] * XY[0] + (cnt-E[j]) * CD[0][j]
        E2[j] %= MOD
    E = E2
    cnt = cnt2
    cnt2 = (cnt * XY[1]) % MOD
    for j in range(18):
        E2[j] = E[j] * CD[1][j]
        E2[j] %= MOD
    E = E2
    cnt = cnt2

ans = 0

for i in range(18):
    ans += E[i] * pow(2,i,MOD)
    ans %= MOD
print(ans)
0