제출 #960550

#제출 시각아이디문제언어결과실행 시간메모리
960550Tuanlinh123Minerals (JOI19_minerals)C++17
80 / 100
32 ms5104 KiB
#include "minerals.h" #include<bits/stdc++.h> #define ll long long #define pb push_back #define sz(a) ((ll)(a).size()) using namespace std; void Solve(int n) { ll crr=0; vector <ll> A, B, a(n*2+1, 0); auto flip=[&](ll idx) { ll x=Query(idx)-crr; crr+=x, a[idx]^=1; return x; }; for (ll i=1; i<=n*2; i++) { if (flip(i)) A.pb(i); else B.pb(i); } function <void(vector <ll>, vector <ll>, bool)> solve=[&](vector <ll> L, vector <ll> R, bool cr) { ll n=sz(L); if (n==1) {Answer(L[0], R[0]); return;} vector <ll> left, right; for (ll i=0; i<n/2; i++) flip(L[i]); for (ll i:R) (a[i]^(a[i]+flip(i))^cr?right:left).pb(i); solve(vector <ll> (L.begin(), L.begin()+n/2), left, cr^1); solve(vector <ll> (L.begin()+n/2, L.end()), right, cr); }; solve(A, B, 1); }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...