Submission #1070429

#TimeUsernameProblemLanguageResultExecution timeMemory
1070429_8_8_Xylophone (JOI18_xylophone)C++17
0 / 100
1 ms344 KiB
#include "xylophone.h" #include <bits/stdc++.h> using namespace std; int p[5002],a[5002]; void solve(int n) { int nd = n - 1; int l = 1,r = n; while(r - l > 1) { int mid = (l + r) >> 1; if(query(1,mid) == nd) { r = mid; } else { l = mid; } } p[n] = r; l = 1,r = p[n]; while(r - l > 1) { int mid = (l + r) >> 1; if(query(mid,r) == nd) { l = mid; } else { r = mid; } } p[1] = l; a[p[1]] = 1; a[p[n]] = n; int mx = 1; for(int i = p[1] - 1;i >= 1;i--) { int val, T; T = query(i,p[1]); if(T != mx - 1) { val = mx = 1 + T; } else { int t2, t1; t2 = query(i,i + 2); t1 = query(i + 1,i + 2); int t = query(i,i + 1); if(a[i + 2] < a[i + 1]) { if(t2 != t1) { val = a[i + 1] - t; } else { val = a[i + 1] + t; } } else { if(t2 != t1) { val = a[i + 1] + t; } else { val = a[i + 1] - t; } } } p[val] = i; a[i] = val; } mx = 1; for(int i = p[1] + 1;i < p[n];i++) { int val, T; T = query(p[1],i); if(T != mx - 1) { val = mx = 1 + T; } else { int t2, t1; t2 = query(i - 2,i - 1); t1 = query(i - 2,i); int t = query(i - 1,i); if(a[i - 2] > a[i - 1]) { if(t2 != t1) { val = a[i - 1] - t; } else { val = a[i - 1] + t; } } else { if(t2 != t1) { val = a[i - 1] + t; } else { val = a[i - 1] - t; } } } p[val] = i; a[i] = val; } int mn = n; for(int i = p[n] + 1;i <= n;i++) { int val, T = query(p[n],i); if(T != n - mn) { mn = val = n - T; } else { int t1, t2; t2 = query(i - 2,i - 1); t1 = query(i - 2,i); int t = query(i - 1,i); if(a[i - 2] > a[i - 1]) { if(t2 != t1) { val = a[i - 1] - t; } else { val = a[i - 1] + t; } } else { if(t2 != t1) { val = a[i - 1] + t; } else { val = a[i - 1] - t; } } } p[val] = i; a[i] = val; } for(int i = 1;i <= n;i++) { answer(p[i],i); } }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...