제출 #643455

#제출 시각아이디문제언어결과실행 시간메모리
643455makanhuliaBall Machine (BOI13_ballmachine)C++17
100 / 100
155 ms24188 KiB
#include <bits/stdc++.h> using namespace std; const int N = 1e5; const int LOG = 18; vector<int>adj[N + 2]; bool mark[N + 2]; int n, q, root; int p[N + 2], mini[N + 2], in[N + 2], depth[N + 2], t[N + 2]; int up[N + 2][LOG]; priority_queue<pair<int, int>, vector<pair<int, int>>, greater<pair<int, int>>>pq; int timer = 1; bool byMin(int &a, int &b){ return mini[a] < mini[b]; } void dfs(int cur, int d){ depth[cur] = d; up[cur][0] = p[cur]; for(int i = 1; i < LOG; i++){ up[cur][i] = up[up[cur][i - 1]][i - 1]; } for(auto &nxt: adj[cur]){ dfs(nxt, d + 1); } t[cur] = timer; pq.emplace(timer++, cur); } int main(){ ios_base::sync_with_stdio(0); cin.tie(0); cout.tie(0); cin >> n >> q; for(int i = 1; i <= n; i++){ cin >> p[i]; if(p[i] == 0) root = i; adj[p[i]].push_back(i); in[p[i]]++; } queue<int>leaf; for(int i = 1; i <= n; i++){ mini[i] = i; if(!in[i]) leaf.push(i); } while(!leaf.empty()){ int cur = leaf.front(); leaf.pop(); int nxt = p[cur]; mini[nxt] = min(mini[cur], mini[nxt]); in[nxt]--; if(!in[nxt]) leaf.push(nxt); } for(int i = 1; i <= n; i++){ if(!adj[i].empty()) sort(adj[i].begin(), adj[i].end(), byMin); } dfs(root, 0); while(q--){ int a, x; cin >> a >> x; if(a == 1){ for(int i = 0; i < x; i++){ if(i + 1 == x) cout << pq.top().second << '\n'; mark[pq.top().second] = true; pq.pop(); } } else{ int tmp = x; for(int i = LOG - 1; i >= 0; i--){ if(mark[up[tmp][i]]) tmp = up[tmp][i]; } mark[tmp] = false; pq.emplace(t[tmp], tmp); cout << depth[x] - depth[tmp] << '\n'; } } return 0; }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...