Submission #907366

#TimeUsernameProblemLanguageResultExecution timeMemory
907366TymondPermutation (APIO22_perm)C++17
0 / 100
1 ms348 KiB
#include <bits/stdc++.h> #include "perm.h" using namespace std; using ll = long long; using ld = long double; const ld INF = 1e9; void zmien(vector<ld>& a){ vector<ld> nasz = a; sort(nasz.begin(), nasz.end()); for (auto &it : a){ it = lower_bound(nasz.begin(), nasz.end(), it) - nasz.begin(); } } vector<signed> construct_permutation(ll k){ ios_base::sync_with_stdio(0); cin.tie(0); cout.tie(0); int aktBit = 64 - __builtin_clzll(k); vector<ld> ans; bool bylo = false; while(aktBit > 0){ aktBit -= 2; if(aktBit == -1){ //został jeden na końcu ans.push_back(INF);//n * 2 if(k & 1){ ans.push_back(-INF);//n + 1 } zmien(ans); continue; } int kon = (k >> aktBit) & 3; if(ans.size() == 0){ if(kon == 2){ ans = {0}; }else{ ans = {1, 0}; bylo = true; } zmien(ans); continue; } if(kon == 0){ //n * 4 ans.push_back(INF); ans.push_back(INF + 1); }else if(kon == 1){ //n * 4 + 1 ans.push_back(INF); ans.push_back(INF + 1); ans.push_back(-INF); bylo = true; }else if(kon == 2){ //n * 4 + 2 ans.push_back(INF); ans.push_back(-INF); ans.push_back(INF + 1); bylo = true; }else if(kon == 3){ //4 * n + 3 if(bylo){ ans.push_back(INF); ans.push_back(-INF); ans.push_back(INF + 1); ans.push_back(-INF - 1); bylo = true; }else{ ans.push_back(INF); ans.push_back(INF + 1); ans.push_back(0.5); } } zmien(ans); } return vector<signed> (ans.begin(), ans.end()); }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...