結果
問題 | No.3046 White Tiger vs Monster |
ユーザー |
|
提出日時 | 2025-03-22 20:41:09 |
言語 | C++23 (gcc 13.3.0 + boost 1.87.0) |
結果 |
WA
|
実行時間 | - |
コード長 | 1,813 bytes |
コンパイル時間 | 3,360 ms |
コンパイル使用メモリ | 278,892 KB |
実行使用メモリ | 7,328 KB |
最終ジャッジ日時 | 2025-03-22 22:33:43 |
合計ジャッジ時間 | 11,943 ms |
ジャッジサーバーID (参考情報) |
judge4 / judge2 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 77 WA * 3 |
ソースコード
#include <bits/stdc++.h>#define eb emplace_backusing namespace std;using ll = long long;ll n,b,a[200000],d,g[60][60];int main(){cin >> n >> b;for(int i = 0; i < n; i++) cin >> a[i];for(int i = 60; i >= 0; i--){if((1ll << i) & b){d = i;break;}}vector<ll> eq,low;for(int i = 0; i < n; i++){int tmp = 0;for(int j = 60; j >= 0; j--){if((1ll << j) & a[i]){tmp = j;break;}}if(tmp == d){eq.eb(a[i]);}if(tmp < d){low.eb(a[i]);}}for(int i = 0; i < d; i++){for(int j = 0; j < d; j++) g[i][j] = 1;}for(int i = 0; i < low.size(); i++){b ^= low[i];int tmp = 0;for(int j = 60; j >= 0; j--){if(low[i] & (1ll << j)){tmp = j;break;}}for(int j = 0; j < tmp; j++){if(~low[i] >> j & 1){g[j][tmp] = 1;}}}for(int k = 0; k < d; k++){for(int i = 0; i < d; i++){for(int j = 0; j < d; j++){g[i][j] |= (g[i][k] & g[k][j]);}}}for(int i = 0; i < eq.size(); i++){if((b ^ eq[i]) == 0){cout << low.size() + 1;return 0;}ll tmp = b ^eq[i],e = 0;for(int j = 60; j >= 0; j--){if((tmp & (1ll << j))){e = j;break;}}for(int j = e; j < d; j++){if(~eq[i]>>j&1&g[e][j] ){cout << low.size() + 1;return 0;}}}cout << low.size() << endl;}