結果
問題 | No.1245 ANDORゲーム(calc) |
ユーザー |
![]() |
提出日時 | 2020-10-02 23:17:23 |
言語 | C++14 (gcc 13.3.0 + boost 1.87.0) |
結果 |
AC
|
実行時間 | 272 ms / 2,000 ms |
コード長 | 1,309 bytes |
コンパイル時間 | 1,823 ms |
コンパイル使用メモリ | 172,944 KB |
実行使用メモリ | 6,944 KB |
最終ジャッジ日時 | 2024-07-17 23:43:23 |
合計ジャッジ時間 | 8,243 ms |
ジャッジサーバーID (参考情報) |
judge3 / judge5 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 25 |
ソースコード
#include<bits/stdc++.h>using namespace std;//#define int long long#define REP(i,m,n) for(int i=(m);i<(n);i++)#define rep(i,n) REP(i,0,n)#define pb push_back#define all(a) a.begin(),a.end()#define rall(c) (c).rbegin(),(c).rend()#define mp make_pair#define endl '\n'#define vec vector<ll>#define mat vector<vector<ll> >#define fi first#define se secondtypedef long long ll;typedef unsigned long long ull;typedef pair<ll,ll> pll;typedef long double ld;typedef complex<double> comp;const ll INF=1e9+7;const ll inf=INF;const ll MOD=998244353;const ll mod=MOD;const int MAX=200010;signed main(){ll n,q;cin>>n>>q;vector<ll>a(n);rep(i,n)cin>>a[i];string s;cin>>s;vector<vector<ll> >d(33,vector<ll>(2));rep(i,33){rep(j,2){ll v=j*(1LL<<i);ll res=0;rep(k,n){if(s[k]=='0'){if((v&a[k])!=v)res+=1LL<<i;v&=a[k];}else{if((v|((1LL<<i)&a[k]))!=v)res+=1LL<<i;v|=((1LL<<i)&a[k]);}}d[i][j]=res;}}while(q--){ll t;cin>>t;ll ans=0;rep(i,33){ans+=d[i][((1LL<<i)&t)>0];}cout<<ans<<endl;}}