#include <iostream>
#include <bits/stdc++.h>
using namespace std;
#define MAXI 10000001
vector<int>height(MAXI);
void dfs(int node,vector<vector<int>>graph,vector<bool>&visited,vector<int>&parent){
visited[node]=true;
for(auto it:graph[node]){
if(!visited[it]){
parent[it]=node;
dfs(it,graph,visited,parent);
}
}
int h=0;
for(auto it: graph[node]){
if(it==parent[node]){
//ignore
}
else{
h=max(h,height[it]);
}
}
height[node]=1+h;
}
int main(){
int n;
cin>>n;
vector<vector<int>>graph(n);
int i=1;
int m=n-1;
while(i<=m){
int x,y;
cin>>x>>y;
x--,y--;
graph[x].push_back(y);
graph[y].push_back(x);
i++;
}
vector<bool>visited(n,false);
vector<int>parent(n,-1);
dfs(0,graph,visited,parent);
for(int i=0;i<n;i++){
cout<<"Height of node "<<i+1<<" : "<<height[i]<<endl;
}
return 0;
}
I2luY2x1ZGUgPGlvc3RyZWFtPgojaW5jbHVkZSA8Yml0cy9zdGRjKysuaD4KdXNpbmcgbmFtZXNwYWNlIHN0ZDsKCiNkZWZpbmUgTUFYSSAxMDAwMDAwMQp2ZWN0b3I8aW50PmhlaWdodChNQVhJKTsKCnZvaWQgZGZzKGludCBub2RlLHZlY3Rvcjx2ZWN0b3I8aW50Pj5ncmFwaCx2ZWN0b3I8Ym9vbD4mdmlzaXRlZCx2ZWN0b3I8aW50PiZwYXJlbnQpewoJdmlzaXRlZFtub2RlXT10cnVlOwoJCglmb3IoYXV0byBpdDpncmFwaFtub2RlXSl7CgkJaWYoIXZpc2l0ZWRbaXRdKXsKCQkJcGFyZW50W2l0XT1ub2RlOwoJCQlkZnMoaXQsZ3JhcGgsdmlzaXRlZCxwYXJlbnQpOwoJCX0KCX0KCQoJaW50IGg9MDsKCQoJZm9yKGF1dG8gaXQ6IGdyYXBoW25vZGVdKXsKCQlpZihpdD09cGFyZW50W25vZGVdKXsKCQkJLy9pZ25vcmUKCQl9CgkJCgkJZWxzZXsKCQkJaD1tYXgoaCxoZWlnaHRbaXRdKTsKCQl9CgkJCgl9CgkKCWhlaWdodFtub2RlXT0xK2g7Cn0KCmludCBtYWluKCl7CglpbnQgbjsKCWNpbj4+bjsKCQoJdmVjdG9yPHZlY3RvcjxpbnQ+PmdyYXBoKG4pOwoJaW50IGk9MTsKCWludCBtPW4tMTsKCQoJd2hpbGUoaTw9bSl7CgkJaW50IHgseTsKCQljaW4+Png+Pnk7CgkJeC0tLHktLTsKCQlncmFwaFt4XS5wdXNoX2JhY2soeSk7CgkJZ3JhcGhbeV0ucHVzaF9iYWNrKHgpOwoJCQoJCWkrKzsKCX0KCQoJdmVjdG9yPGJvb2w+dmlzaXRlZChuLGZhbHNlKTsKCXZlY3RvcjxpbnQ+cGFyZW50KG4sLTEpOwoJCgkKCWRmcygwLGdyYXBoLHZpc2l0ZWQscGFyZW50KTsKCWZvcihpbnQgaT0wO2k8bjtpKyspewoJCWNvdXQ8PCJIZWlnaHQgb2Ygbm9kZSAiPDxpKzE8PCIgOiAiPDxoZWlnaHRbaV08PGVuZGw7Cgl9CgkKCXJldHVybiAwOwoJCgkKfQ==