#include <bits/stdc++.h>
using namespace std;
const int maxn=2*1e5+10;
struct st{
int g,s,b,paihao;
}a[maxn];
int ans[maxn];
bool cmp1(st a,st b){
return a.g>b.g;
}
bool cmp2(st a,st b){
return a.s>b.s;
}
bool cmp3(st a,st b){
return a.b>b.b;
}
int main() {
int n;
cin>>n;
for(int i=1;i<=n;i++){
cin>>a[i].g>>a[i].s>>a[i].b;
a[i].paihao=i;
}
sort(a+1,a+n+1,cmp1);
ans[a[1].paihao]=1;
for(int i=2;i<=n;i++){
if(a[i].g==a[i-1].g){
ans[a[i].paihao]=i-1;
}else{
ans[a[i].paihao]=i;
}
}
sort(a+1,a+n+1,cmp2);
ans[a[1].paihao]=1;
for(int i=2;i<=n;i++){
if(a[i].s==a[i-1].s){
ans[a[i].paihao]=min(ans[a[i].paihao],i-1);
}else{
ans[a[i].paihao]=min(ans[a[i].paihao],i);
}
}
sort(a+1,a+n+1,cmp3);
ans[a[1].paihao]=1;
for(int i=2;i<=n;i++){
if(a[i].b==a[i-1].b){
ans[a[i].paihao]=min(ans[a[i].paihao],i-1);
}else{
ans[a[i].paihao]=min(ans[a[i].paihao],i);
}
}
for(int i=1;i<=n;i++){
cout<<ans[i]<<endl;
}
return 0;
}