Advertisement
Ahmed_Negm

subarray bits

Aug 7th, 2023
553
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
C++ 2.63 KB | None | 0 0
  1. #include <bits/stdc++.h>
  2. #include <ext/pb_ds/assoc_container.hpp>
  3. #include <ext/pb_ds/tree_policy.hpp>
  4. using namespace std;
  5. using namespace __gnu_pbds;
  6. #define ll long long
  7. #define OO 2'000'000'000
  8. #define ull unsigned long long
  9. #define nl '\n'
  10. #define sz(x) (ll)(x.size())
  11. #define all(x) x.begin(),x.end()
  12. #define rall(s)  s.rbegin(), s.rend()
  13. #define getline(s) getline(cin>>ws,s)
  14. #define ceill(n, m) (((n) / (m)) + ((n) % (m) ? 1 : 0))
  15. #define pi  3.141592653589793
  16. #define ordered_set tree<int, null_type,less<int>, rb_tree_tag,tree_order_statistics_node_update>
  17. #define multi_ordered_set tree<int, null_type,less_equal<int>, rb_tree_tag,tree_order_statistics_node_update>
  18.  
  19.  
  20. void Fast_IO(){
  21. ios_base::sync_with_stdio(false), cin.tie(nullptr), cout.tie(nullptr);
  22. // freopen("filename.in", "r", stdin);
  23. // freopen("filename.out", "w", stdout);
  24. #ifndef ONLINE_JUDGE
  25. freopen("input.txt", "r", stdin), freopen("output.txt", "w", stdout);
  26. #endif
  27. }
  28.  
  29.  
  30.  
  31.  
  32. int dx[] = { 2, 1, -1, -2, -2, -1, 1, 2 };
  33. int dy[] = { 1, 2, 2, 1, -1, -2, -2, -1 };
  34.  
  35.  
  36.  
  37.  
  38. void solve(){
  39.   ll n,x,a,o;
  40.   cin>>n>>x>>a>>o;
  41.  
  42.     vector<ll> v(n);
  43.     for(int i=0;i<n;i++){
  44.         cin>>v[i];
  45.     }
  46.     ll len = -1;
  47.  
  48.    
  49.    
  50.  
  51.     vector<ll> freqbits(64),freqbits2(64);
  52.     ll XOR = 0,OR = 0,AND = v[0];
  53.     ll l=0,r=0;
  54.     for(;r<n;r++){
  55.         for(int i=0;i<64;i++){
  56.             if(v[r]&(1LL<<i)){
  57.                 freqbits[i]++;
  58.             }else freqbits2[i]++;
  59.         }
  60.         XOR^=v[r];
  61.         OR|=v[r];
  62.         AND&=v[r];
  63.         // cout<<l<<" "<<r<<nl;
  64.         // cout<<XOR<<" "<<OR<<" "<<AND<<nl;
  65.  
  66.         while(l<r and (XOR>x or OR>o or AND>a)){
  67.             for(int i=0;i<64;i++){
  68.                 if(v[l]&1LL<<i){
  69.                     if(freqbits[i]&1){
  70.                         XOR^=(1LL<<i);
  71.                     }
  72.                     if(freqbits[i]==1){
  73.                         OR^=(1LL<<i);
  74.                     }
  75.                     freqbits[i]--;
  76.                 }else{
  77.                     if(freqbits2[i]==1){
  78.                         AND^=(1LL<<i);
  79.                     }
  80.                     freqbits2[i]--;
  81.                 }
  82.             }
  83.             l++;
  84.         }
  85.         // cout<<l<<" "<<r<<nl;
  86.         // cout<<XOR<<" "<<OR<<" "<<AND<<nl;
  87.  
  88.         // find the xor , or , and of every pair in this range
  89.  
  90.    
  91.  
  92.         if(XOR<=x and OR<=o and AND<=a){
  93.             // cout<<l<<' '<<r<<nl;
  94.             // cout<<XOR<<" "<<OR<<" "<<AND<<nl;
  95.             len = max(len,r-l+1);
  96.         }
  97.  
  98.     }
  99.     cout<<len<<nl;
  100.  
  101.  
  102.  
  103.  
  104. }
  105.  
  106. int main(){
  107.     Fast_IO();
  108. int t =1;
  109. cin>>t;
  110. while(t--){
  111. solve();
  112. }
  113. return 0;
  114. }  
  115.  
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement