Submission #1088803

# Submission time Handle Problem Language Result Execution time Memory
1088803 2024-09-15T06:27:02 Z coldbr3w Tree Rotations (POI11_rot) C++17
100 / 100
212 ms 48980 KB
//#pragma GCC optimize("O3","unroll-loops")
#include<bits/stdc++.h>
#define all(x) (x).begin() , (x).end()
#define pll pair<long long, long long>
#define pii pair<int , int>
#define fi first
#define se second
#define bit(i,j) ((j >> i) & 1)
using namespace std;

const long long inf = 1e18+1;
const int mod = 1e9+7;
const int MAXN = 1e6+100;

#define int long long

int bit[MAXN] , n;
void upd(int x , int val){
	while(x <= n){
		bit[x] += val;
		x += (x & (-x));
	}
}
int get(int x){
	int res = 0;
	while(x > 0){
		res += bit[x];
		x -= (x & (-x));
	}
	return res;
}

vector<int> adj[MAXN];
int id = 1 , c[MAXN] , sz[MAXN];
void Input(){
	int x; cin >> x;
	c[id] = x;
	if(x!=0) return;
	int t = id;
	adj[t].push_back(id+1);
	id++ ; Input();
	adj[t].push_back(id+1);
	id++ ; Input();
}

void dfs_sz(int u){
	sz[u] = 1;
	for(auto v : adj[u]) dfs_sz(v) , sz[u] += sz[v];
}
void modify(int u , int val){
	if(adj[u].size() == 0){
		upd(c[u] , val); return;
	}
	for(auto v : adj[u]) modify(v , val);
}
int cnt1 = 0 , cnt2 = 0;
void cal(int u){
	if(adj[u].size() == 0){
		cnt1 += get(c[u] - 1);
		cnt2 += get(n) - get(c[u]);
		return;
	}
	for(auto v : adj[u]) cal(v);
}
int ans[MAXN];
void dfs(int u){
	if(adj[u].size() == 0){
		upd(c[u] , 1); return;
	}
	int bc = (sz[adj[u][0]] > sz[adj[u][1]] ? 0 : 1);
	int sc = bc ^ 1;
	bc = adj[u][bc]; sc = adj[u][sc];
	dfs(sc);
	modify(sc , -1);
	dfs(bc);
	cnt1 = cnt2 = 0;
	cal(sc);
	modify(sc , 1);
	ans[u] = ans[bc] + ans[sc] + min(cnt1 , cnt2);
}
int32_t main(){
  	//freopen("TRAVEL.INP", "r", stdin);
	//freopen("Nowruz.out", "w", stdout);
	ios_base::sync_with_stdio(0); cin.tie(0);
	
	cin >> n;
	Input();
	dfs_sz(1);
	dfs(1);
	cout << ans[1] << "\n";

	return 0;
}

# Verdict Execution time Memory Grader output
1 Correct 11 ms 23896 KB Output is correct
2 Correct 11 ms 23900 KB Output is correct
3 Correct 10 ms 23768 KB Output is correct
4 Correct 10 ms 23900 KB Output is correct
5 Correct 10 ms 23900 KB Output is correct
# Verdict Execution time Memory Grader output
1 Correct 11 ms 23900 KB Output is correct
2 Correct 10 ms 23900 KB Output is correct
3 Correct 10 ms 23944 KB Output is correct
4 Correct 11 ms 23896 KB Output is correct
# Verdict Execution time Memory Grader output
1 Correct 11 ms 23900 KB Output is correct
2 Correct 10 ms 23884 KB Output is correct
3 Correct 11 ms 23900 KB Output is correct
4 Correct 11 ms 23844 KB Output is correct
# Verdict Execution time Memory Grader output
1 Correct 12 ms 24476 KB Output is correct
2 Correct 14 ms 24156 KB Output is correct
3 Correct 11 ms 24412 KB Output is correct
4 Correct 12 ms 24412 KB Output is correct
# Verdict Execution time Memory Grader output
1 Correct 14 ms 25388 KB Output is correct
2 Correct 19 ms 24924 KB Output is correct
3 Correct 33 ms 26708 KB Output is correct
4 Correct 15 ms 25436 KB Output is correct
# Verdict Execution time Memory Grader output
1 Correct 47 ms 28496 KB Output is correct
2 Correct 32 ms 29532 KB Output is correct
3 Correct 36 ms 30800 KB Output is correct
4 Correct 37 ms 31068 KB Output is correct
# Verdict Execution time Memory Grader output
1 Correct 37 ms 36152 KB Output is correct
2 Correct 47 ms 34452 KB Output is correct
3 Correct 59 ms 33104 KB Output is correct
4 Correct 47 ms 32384 KB Output is correct
# Verdict Execution time Memory Grader output
1 Correct 61 ms 35300 KB Output is correct
2 Correct 59 ms 36180 KB Output is correct
3 Correct 58 ms 38536 KB Output is correct
4 Correct 60 ms 38344 KB Output is correct
# Verdict Execution time Memory Grader output
1 Correct 153 ms 42576 KB Output is correct
2 Correct 112 ms 41536 KB Output is correct
3 Correct 95 ms 41296 KB Output is correct
4 Correct 108 ms 40784 KB Output is correct
5 Correct 171 ms 39764 KB Output is correct
# Verdict Execution time Memory Grader output
1 Correct 105 ms 42320 KB Output is correct
2 Correct 105 ms 47196 KB Output is correct
3 Correct 127 ms 45652 KB Output is correct
4 Correct 93 ms 47956 KB Output is correct
5 Correct 208 ms 42064 KB Output is correct
# Verdict Execution time Memory Grader output
1 Correct 121 ms 42836 KB Output is correct
2 Correct 102 ms 44372 KB Output is correct
3 Correct 171 ms 42704 KB Output is correct
4 Correct 123 ms 43092 KB Output is correct
5 Correct 93 ms 48980 KB Output is correct
6 Correct 212 ms 42796 KB Output is correct