結果

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

ソースコード

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]
    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]
    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