Submission #995218

#TimeUsernameProblemLanguageResultExecution timeMemory
995218Tuanlinh123Xylophone (JOI18_xylophone)C++17
100 / 100
45 ms860 KiB
#include<bits/stdc++.h> #include "xylophone.h" #define ll int using namespace std; ll a[100005]; bool seen[100005]; ll calc(ll a, ll b, ll dis1, ll dis2) { if (a<b) { if (dis1==dis2 || dis2==b-a) return a+dis1; return a-dis1; } if (dis1==dis2 || dis2==a-b) return a-dis1; return a+dis1; } void solve(ll n) { // freopen("output.txt", "w", stdout); ll L=1, R=n; ll lo=L, hi=R, val=query(lo, hi); while (hi-lo>1) { ll mid=(hi+lo)/2; if (query(L, mid)!=val) lo=mid; else hi=mid; } if (query(L, lo)!=val) R=hi; else R=lo; lo=L, hi=R; while (hi-lo>1) { ll mid=(hi+lo)/2; if (query(mid, R)!=val) hi=mid; else lo=mid; } if (query(hi, R)!=val) L=lo; else R=hi; a[L]=1; a[R]=n; // cout << L << " " << R << "\n"; if (L>1) a[L-1]=a[L]+query(L-1, L); a[L+1]=a[L]+query(L, L+1); if (R<n) a[R+1]=a[R]-query(R, R+1); for (ll i=L-2; i>=1; i--) { ll val=query(i, i+1); if (a[i+1]-val<0 || seen[a[i+1]-val]) a[i]=a[i+1]+val; else if (a[i+1]+val>n || seen[a[i+1]+val]) a[i]=a[i+1]-val; else a[i]=calc(a[i+1], a[i+2], val, query(i, i+2)); seen[a[i]]=1; } for (ll i=L+2; i<R; i++) { ll val=query(i-1, i); if (a[i-1]-val<0 || seen[a[i-1]-val]) a[i]=a[i-1]+val; else if (a[i-1]+val>n || seen[a[i-1]+val]) a[i]=a[i-1]-val; else a[i]=calc(a[i-1], a[i-2], val, query(i-2, i)); seen[a[i]]=1; } for (ll i=R+2; i<=n; i++) { ll val=query(i-1, i); if (a[i-1]-val<0 || seen[a[i-1]-val]) a[i]=a[i-1]+val; else if (a[i-1]+val>n || seen[a[i-1]+val]) a[i]=a[i-1]-val; else a[i]=calc(a[i-1], a[i-2], val, query(i-2, i)); seen[a[i]]=1; } // for (ll i=1; i<=n; i++) // cout << a[i] << " "; // cout << "\n"; for (ll i=1; i<=n; i++) answer(i, a[i]); }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...