結果
問題 |
No.1245 ANDORゲーム(calc)
|
ユーザー |
|
提出日時 | 2021-10-07 15:38:45 |
言語 | PyPy3 (7.3.15) |
結果 |
WA
|
実行時間 | - |
コード長 | 767 bytes |
コンパイル時間 | 271 ms |
コンパイル使用メモリ | 82,048 KB |
実行使用メモリ | 98,960 KB |
最終ジャッジ日時 | 2024-07-23 03:06:55 |
合計ジャッジ時間 | 6,400 ms |
ジャッジサーバーID (参考情報) |
judge2 / judge4 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 1 WA * 24 |
ソースコード
N,Q=map(int, input().split()) A=list(map(int, input().split())) S=list(input().rstrip()) T=list(map(int, input().split())) L=10 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)