結果

問題 No.130 XOR Minimax
ユーザー tempura_pptempura_pp
提出日時 2018-10-16 02:01:28
言語 C++11
(gcc 11.4.0)
結果
AC  
実行時間 166 ms / 5,000 ms
コード長 3,806 bytes
コンパイル時間 693 ms
コンパイル使用メモリ 88,264 KB
実行使用メモリ 50,908 KB
最終ジャッジ日時 2023-10-10 00:23:27
合計ジャッジ時間 3,587 ms
ジャッジサーバーID
(参考情報)
judge15 / judge12
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 AC 83 ms
24,088 KB
testcase_01 AC 1 ms
4,348 KB
testcase_02 AC 2 ms
4,348 KB
testcase_03 AC 2 ms
4,352 KB
testcase_04 AC 36 ms
4,348 KB
testcase_05 AC 61 ms
4,352 KB
testcase_06 AC 67 ms
9,712 KB
testcase_07 AC 78 ms
9,696 KB
testcase_08 AC 161 ms
50,908 KB
testcase_09 AC 14 ms
5,152 KB
testcase_10 AC 20 ms
5,700 KB
testcase_11 AC 70 ms
7,940 KB
testcase_12 AC 7 ms
4,408 KB
testcase_13 AC 54 ms
7,592 KB
testcase_14 AC 163 ms
41,664 KB
testcase_15 AC 3 ms
4,352 KB
testcase_16 AC 112 ms
30,956 KB
testcase_17 AC 117 ms
31,952 KB
testcase_18 AC 128 ms
34,048 KB
testcase_19 AC 154 ms
39,288 KB
testcase_20 AC 72 ms
21,752 KB
testcase_21 AC 166 ms
41,252 KB
testcase_22 AC 33 ms
12,240 KB
testcase_23 AC 11 ms
6,188 KB
権限があれば一括ダウンロードができます

ソースコード

diff #

#include<iostream>
#include<string>
#include<algorithm>
#include<vector>
#include<iomanip>
#include<math.h>
#include<complex>
#include<queue>
#include<deque>
#include<stack>
#include<map>
#include<set>
#include<bitset>
#include<functional>
using namespace std;
#define REP(i,m,n) for(int i=(int)m ; i < (int) n ; ++i )
#define rep(i,n) REP(i,0,n)
typedef long long ll;
typedef pair<int,int> pint;
typedef pair<ll,int> pli;
const int inf=1e9+7;
const ll longinf=1LL<<60 ;
const ll mod=1e9+7 ;


template<typename T = unsigned int, int B=32>
struct BinaryTrie{
private:
    struct Node{
        int cnt;
        T lazy;
        Node *ch[2]={};

        Node():cnt(0),lazy(0){}
    };

    Node* root;

    int size(Node *t){return t?t->cnt:0 ;}

    void eval(Node* t,int bit_index){
        if(!t->lazy)return;
        if(t->lazy>>bit_index)swap(t->ch[0],t->ch[1]);
        if(t->ch[0])t->ch[0]->lazy^=t->lazy;
        if(t->ch[1])t->ch[1]->lazy^=t->lazy;
        t->lazy = 0;
    }

    Node* insert(Node* t,T n,int bit_index){
        if(!t)t=new Node;
        t->cnt+=1;
        if(bit_index==-1)return t;
        eval(t,bit_index);
        bool c=(n>>bit_index)&1;
        t->ch[c]=insert(t->ch[c],n,bit_index-1);
        return t;
    }

    Node* erase(Node* t,T n,int bit_index){
        //assert(t);
        t->cnt-=1;
        if(!t->cnt)return nullptr;
        if(bit_index==-1)return t;
        eval(t,bit_index);
        bool c=(n>>bit_index)&1;
        t->ch[c]=erase(t->ch[c],n,bit_index-1);
        return t;
    }

    T get_min(Node* t,T n,int bit_index){
        //assert(t);
        if(bit_index<0)return 0;
        eval(t,bit_index);
        bool c=(n>>bit_index)&1;
        T ret=0;
        if(!t->ch[c])c^=1;
        return get_min(t->ch[c],n,bit_index-1)|((T)c<<bit_index);
    }
    
    T get(Node* t,T n,int k,int bit_index){
        //assert(t&&t->cnt<=k);
        if(bit_index<0)return 0;
        eval(t,bit_index);
        bool c=(n>>bit_index)&1;
        if(size(t->ch[c])<k)k-=size(t->ch[c]),c^=1;
        return get(t->ch[c],n,k,bit_index-1)|((T)c<<bit_index);
    }

    int count_lower(Node* t,T n,T val,int bit_index){
        if(!t||bit_index<0)return 0;
        eval(t,bit_index);
        bool c=(n>>bit_index)&1;
        int ret=0;
        if((val>>bit_index)&1)ret+=size(t->ch[c]),c^=1;
        return ret+count_lower(t->ch[c],n,val,bit_index-1);
    }

    T calc(Node* t,int bit_index){
        if(!t||bit_index<0)return 0;
        if(size(t->ch[0])==0)return calc(t->ch[1],bit_index-1);
        if(size(t->ch[1])==0)return calc(t->ch[0],bit_index-1);
        T ret= (1LL<<bit_index)+min(calc(t->ch[0],bit_index-1),calc(t->ch[1],bit_index-1));
        return ret;
    }

public:
    BinaryTrie():root(nullptr){}

    int size(){
        return size(root);
    }

    bool empty(){
        return !root;
    }

    void insert(T n){
        root=insert(root,n,B-1);

    }

    void erase(T n){
        root=erase(root,n,B-1);
    }

    void xor_all(T n){
        if(root) root->lazy^=n;
    }

    T max_element(T bias = 0){
        return get_min(root,~bias,B-1);
    }

    T min_element(T bias = 0){
        return get_min(root,bias,B-1);
    }

    int lower_bound(T x,T bias = 0){
        return count_lower(root,bias,x,B-1);
    }

    int upper_bound(T x,T bias = 0){
        return count_lower(root,bias,x+1,B-1);
    }

    int count(T x){
        return upper_bound(x)-lower_bound(x);
    }

    T get(int k,T bias = 0){
        //assert(0<=k&&k<size());
        return get(root,bias,k+1,B-1);
    }

    T operator[](int k){
        return get(k);
    }

    T calc(){
        return calc(root,B-1);
    }

};

int main(){
    int n;cin>>n;
    BinaryTrie<> bt;
    rep(i,n){
        int x;cin>>x;
        bt.insert(x);
    }
    cout<<bt.calc()<<endl;
}
0