Submission #684863

#TimeUsernameProblemLanguageResultExecution timeMemory
684863happypotatoPermutation (APIO22_perm)C++17
91.33 / 100
2 ms340 KiB
#include "perm.h" #include <bits/stdc++.h> using namespace std; void discretise(vector<int> &v) { map<int, int> mp; for (int i = 0; i < (int)(v.size()); i++) { mp[v[i]] = i; } int cnt = 0; for (pair<int, int> cur : mp) { v[cur.second] = cnt++; } } vector<int> ans; int multi, take, notake; void recur(long long k) { if (k == 2) { ans = {0}; return; } if (k & 1) { recur(k - 1); ans.push_back(notake--); } else { recur(k / 2); ans.push_back(multi++); } } void checking(vector<int> &v) { int n = v.size(); long long dp[n]; long long tot = 1; for (int i = 0; i < n; i++) { dp[i] = 1; for (int j = 0; j < i; j++) { if (v[j] < v[i]) { dp[i] += dp[j]; } } tot += dp[i]; } cout << "Total number of subsequences is " << tot << endl; } vector<int> construct_permutation(long long k) { ans.clear(); multi = 1; notake = -1; recur(k); discretise(ans); // cout << "Answer: "; // for (int &x : ans) cout << x << ' '; cout << endl; // checking(ans); return ans; }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...