結果
問題 |
No.1245 ANDORゲーム(calc)
|
ユーザー |
|
提出日時 | 2021-10-07 15:39:12 |
言語 | PyPy3 (7.3.15) |
結果 |
AC
|
実行時間 | 301 ms / 2,000 ms |
コード長 | 767 bytes |
コンパイル時間 | 270 ms |
コンパイル使用メモリ | 82,304 KB |
実行使用メモリ | 98,648 KB |
最終ジャッジ日時 | 2024-07-23 03:07:03 |
合計ジャッジ時間 | 8,306 ms |
ジャッジサーバーID (参考情報) |
judge1 / judge2 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 25 |
ソースコード
N,Q=map(int, input().split()) A=list(map(int, input().split())) S=list(input().rstrip()) T=list(map(int, input().split())) L=64 sim1=[1]*L sco1=[0]*L sim0=[0]*L sco0=[0]*L for i in range(N): a,s=A[i],S[i] if s=="0": for i in range(L): sco1[i]+=sim1[i]-(sim1[i]&((a>>i)&1)) sim1[i]&=((a>>i)&1) sco0[i]+=sim0[i]-(sim0[i]&((a>>i)&1)) sim0[i]&=((a>>i)&1) else: for i in range(L): sco1[i]+=(sim1[i]|((a>>i)&1))-sim1[i] sim1[i]|=((a>>i)&1) sco0[i]+=(sim0[i]|((a>>i)&1))-sim0[i] sim0[i]|=((a>>i)&1) for t in T: res=0 for i in range(L): if t&(1<<i): res+=sco1[i]<<i else: res+=sco0[i]<<i print(res)