# | Submission time | Handle | Problem | Language | Result | Execution time | Memory |
---|---|---|---|---|---|---|---|
1054162 | 2024-08-12T07:09:13 Z | huutuan | Secret Permutation (RMI19_permutation) | C++14 | 7 ms | 344 KB |
#include "permutation.h" #include <bits/stdc++.h> using namespace std; mt19937 rng(69420); int rand(int l, int r){ return uniform_int_distribution<int>(l, r)(rng); } void solve(int n) { vector<int> ans(n+1); vector<int> v(n); iota(v.begin(), v.end(), 1); vector<int> d1(n+1); for (int i=0; i<n; ++i){ d1[v[0]]=query(v); rotate(v.begin(), v.begin()+1, v.end()); } int sum=accumulate(d1.begin(), d1.end(), 0)/(n-1); for (int &i:d1) i=sum-i; auto find=[&](int x, int y){ if (x>y) swap(x, y); if (y-x==1) return d1[y]; if (y-x==n-1) return d1[1]; vector<int> vv(n); iota(vv.begin(), vv.end(), 1); rotate(vv.begin(), vv.begin()+x-1, vv.end()); reverse(vv.begin(), vv.begin()+y-x); int s=query(vv); for (int i=1; i<n; ++i){ if (abs(vv[i]-vv[i-1])==1){ s-=d1[max(vv[i], vv[i-1])]; }else if (abs(vv[i]-vv[i-1])==n-1){ s-=d1[1]; } } return s; }; ans[2]=ans[1]+d1[2]; for (int i=3; i+1<=n; i+=2){ int t=find(i-2, i+1); int msk=0; if (abs(ans[i-1]-ans[i-2]+d1[i]+d1[i+1])==t){ msk|=1; ans[i]=ans[i-1]+d1[i]; ans[i+1]=ans[i]+d1[i+1]; } if (abs(ans[i-1]-ans[i-2]+d1[i]-d1[i+1])==t){ msk|=2; ans[i]=ans[i-1]+d1[i]; ans[i+1]=ans[i]-d1[i+1]; } if (abs(ans[i-1]-ans[i-2]-d1[i]+d1[i+1])==t){ msk|=4; ans[i]=ans[i-1]-d1[i]; ans[i+1]=ans[i]+d1[i+1]; } if (abs(ans[i-1]-ans[i-2]-d1[i]-d1[i+1])==t){ msk|=8; ans[i]=ans[i-1]-d1[i]; ans[i+1]=ans[i]-d1[i+1]; } if (__builtin_popcount(msk)!=1){ int tt=find(i-2, i); if (tt==abs(ans[i-1]-ans[i-2]+d1[i])) ans[i]=ans[i-1]+d1[i]; else ans[i]=ans[i-1]-d1[i]; if (t==abs(ans[i]-ans[i-2]+d1[i+1])) ans[i+1]=ans[i]+d1[i+1]; else ans[i+1]=ans[i]-d1[i+1]; } } if (n&1){ int t=find(n-2, n); if (abs(ans[n-1]-ans[n-2]+d1[n])==t){ ans[n]=ans[n-1]+d1[n]; }else{ ans[n]=ans[n-1]-d1[n]; } } ans.erase(ans.begin()); int mn=*min_element(ans.begin(), ans.end()); for (int &i:ans) i-=mn-1; answer(ans); }
Compilation message
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
1 | Partially correct | 0 ms | 344 KB | Partially correct |
2 | Partially correct | 0 ms | 344 KB | Partially correct |
3 | Partially correct | 0 ms | 344 KB | Partially correct |
4 | Partially correct | 0 ms | 344 KB | Partially correct |
5 | Partially correct | 0 ms | 344 KB | Partially correct |
6 | Partially correct | 0 ms | 344 KB | Partially correct |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
1 | Partially correct | 0 ms | 344 KB | Partially correct |
2 | Partially correct | 0 ms | 344 KB | Partially correct |
3 | Partially correct | 0 ms | 344 KB | Partially correct |
4 | Partially correct | 0 ms | 344 KB | Partially correct |
5 | Partially correct | 0 ms | 344 KB | Partially correct |
6 | Partially correct | 0 ms | 344 KB | Partially correct |
7 | Partially correct | 1 ms | 344 KB | Partially correct |
8 | Partially correct | 1 ms | 344 KB | Partially correct |
9 | Partially correct | 0 ms | 344 KB | Partially correct |
10 | Partially correct | 1 ms | 344 KB | Partially correct |
11 | Partially correct | 0 ms | 344 KB | Partially correct |
12 | Partially correct | 1 ms | 344 KB | Partially correct |
13 | Partially correct | 0 ms | 344 KB | Partially correct |
14 | Partially correct | 0 ms | 344 KB | Partially correct |
15 | Partially correct | 0 ms | 344 KB | Partially correct |
16 | Partially correct | 1 ms | 344 KB | Partially correct |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
1 | Partially correct | 0 ms | 344 KB | Partially correct |
2 | Partially correct | 0 ms | 344 KB | Partially correct |
3 | Partially correct | 0 ms | 344 KB | Partially correct |
4 | Partially correct | 0 ms | 344 KB | Partially correct |
5 | Partially correct | 0 ms | 344 KB | Partially correct |
6 | Partially correct | 0 ms | 344 KB | Partially correct |
7 | Partially correct | 1 ms | 344 KB | Partially correct |
8 | Partially correct | 1 ms | 344 KB | Partially correct |
9 | Partially correct | 0 ms | 344 KB | Partially correct |
10 | Partially correct | 1 ms | 344 KB | Partially correct |
11 | Partially correct | 0 ms | 344 KB | Partially correct |
12 | Partially correct | 1 ms | 344 KB | Partially correct |
13 | Partially correct | 0 ms | 344 KB | Partially correct |
14 | Partially correct | 0 ms | 344 KB | Partially correct |
15 | Partially correct | 0 ms | 344 KB | Partially correct |
16 | Partially correct | 1 ms | 344 KB | Partially correct |
17 | Partially correct | 6 ms | 344 KB | Partially correct |
18 | Partially correct | 5 ms | 344 KB | Partially correct |
19 | Partially correct | 6 ms | 344 KB | Partially correct |
20 | Partially correct | 6 ms | 340 KB | Partially correct |
21 | Partially correct | 6 ms | 344 KB | Partially correct |
22 | Partially correct | 6 ms | 344 KB | Partially correct |
23 | Partially correct | 7 ms | 344 KB | Partially correct |
24 | Partially correct | 6 ms | 340 KB | Partially correct |
25 | Partially correct | 6 ms | 344 KB | Partially correct |
26 | Partially correct | 6 ms | 344 KB | Partially correct |