結果
| 問題 | No.1958 Bit Game |
| コンテスト | |
| ユーザー |
ntuda
|
| 提出日時 | 2025-12-02 21:19:07 |
| 言語 | PyPy3 (7.3.15) |
| 結果 |
AC
|
| 実行時間 | 368 ms / 2,000 ms |
| コード長 | 766 bytes |
| 記録 | |
| コンパイル時間 | 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 |
ソースコード
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)
ntuda