Submission #829754

#TimeUsernameProblemLanguageResultExecution timeMemory
829754bachhoangxuanMechanical Doll (IOI18_doll)C++17
100 / 100
124 ms11084 KiB
#include "doll.h"
#include <bits/stdc++.h>
using namespace std;
const int maxn=3e5+5;


void create_circuit(int M, std::vector<int> A) {
    vector<int> s(M+1,-1),x(maxn,0),y(maxn,0),z(maxn,0);
    A.push_back(0);
    int n=(int)A.size(),sz=1,cnt=0;
    while(sz<n) sz*=2;

    function<int(int,int)> dnc = [&](int l,int r){
        if(l>=n) return -1;
        if(r-l>1){
            int mid=(l+r)>>1,u=cnt++;
            y[u]=dnc(l,mid);x[u]=dnc(mid,r);
            return -(u+1);
        }
        return 1;
    };
    dnc(0,sz);

    for(int i:A){
        int u=0;
        while(u>=0){
            z[u]^=1;
            int &w = z[u]?x[u]:y[u];
            if(w>=0){w=i;break;}
            else u=-1-w;
        }
    }
    x.resize(cnt);
    y.resize(cnt);
    answer(s,x,y);
}
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...