35分求助
查看原帖
35分求助
1449802
Bobby2024楼主2024/10/23 21:20
#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;
}
2024/10/23 21:20
加载中...