Submission #1100474

#TimeUsernameProblemLanguageResultExecution timeMemory
1100474LuvidiUnscrambling a Messy Bug (IOI16_messy)C++17
38 / 100
1 ms592 KiB
#include <vector>
#include <bits/stdc++.h>
#include "messy.h"
using namespace std;

mt19937_64 rng(chrono::steady_clock::now().time_since_epoch().count());

std::vector<int> restore_permutation(int n, int w, int r) {
    vector<int> p(n);
    iota(begin(p),end(p),0);
    shuffle(begin(p),end(p),rng);
    string s;
    for(int i=0;i<n;i++)s+='0';
    for(int i=0;i<n;i++){
        s[p[i]]='1';
        add_element(s);
    }
    compile_set();
    vector<int> ans(n);
    for(int i=0;i<n;i++)s[i]='0';
    for(int i=0;i<n;i++){
        for(int j=0;j<n;j++)if(s[j]=='0'){
            s[j]='1';
            if(check_element(s)){
                ans[j]=p[i];
                break;
            }
            s[j]='0';
        }
    }
    return ans;
}
#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...