結果
| 問題 | No.1958 Bit Game |
| コンテスト | |
| ユーザー |
ntuda
|
| 提出日時 | 2025-12-02 21:08:36 |
| 言語 | PyPy3 (7.3.15) |
| 結果 |
TLE
|
| 実行時間 | - |
| コード長 | 747 bytes |
| 記録 | |
| コンパイル時間 | 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 |
ソースコード
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)
ntuda