时间复杂度问题(60pts)
  • 板块P11185 奖牌排序
  • 楼主wsy_I
  • 当前回复8
  • 已保存回复10
  • 发布时间2024/10/15 12:54
  • 上次更新2024/10/15 17:03:37
查看原帖
时间复杂度问题(60pts)
1152799
wsy_I楼主2024/10/15 12:54
#include<bits/stdc++.h>
#define MAXN (int)(2e5+1e1)
#define MAXM (int)(1e1+5)
using namespace std;
int n,p[MAXM][MAXN];
struct node{
	int g,s,b,x;
}a[MAXN],c[MAXN];
void make(int l){
	int nw=1,ls=1;
	for(int i=1;i<=n;i++){
		if(l==1 && c[i].b!=c[ls].b) nw=i,ls=i;
		else if(l==2 && c[i].g!=c[ls].g) nw=i,ls=i;
		else if(l==3 && c[i].s!=c[ls].s) nw=i,ls=i;
		p[l][c[i].x]=nw;
	}
}
bool cmp(node a1,node b1){
	if(a1.b!=b1.b) return a1.b>b1.b;
	else return true;
}
bool cmp2(node a1,node b1){
	if(a1.g!=b1.g) return a1.g>b1.g;
	else return true;
}
bool cmp3(node a1,node b1){
	if(a1.s!=b1.s) return a1.s>b1.s;
	else return true;
}
int main()
{
	ios::sync_with_stdio(0);
	cin.tie(0); cout.tie(0);
	cin>>n;
	for(int i=1;i<=n;i++) cin>>a[i].g>>a[i].s>>a[i].b,a[i].x=i;
	for(int i=1;i<=n;i++) c[i].g=a[i].g,c[i].b=a[i].b,c[i].s=a[i].s,c[i].x=a[i].x;
	sort(c+1,c+n+1,cmp); make(1);
	for(int i=1;i<=n;i++) c[i].g=a[i].g,c[i].b=a[i].b,c[i].s=a[i].s,c[i].x=a[i].x;;
	sort(c+1,c+n+1,cmp2); make(2);
	for(int i=1;i<=n;i++) c[i].g=a[i].g,c[i].b=a[i].b,c[i].s=a[i].s,c[i].x=a[i].x;;
	sort(c+1,c+n+1,cmp3); make(3);
	for(int i=1;i<=n;i++) cout<<min(p[1][i],min(p[2][i],p[3][i]))<<endl;
	return 0;
}

不是明显 O(nlogn)O(n\log n) 吗,在 n2×105n \le 2\times 10^5 的数据范围内,循环不多于 6×1066\times 10^6 次,应该不会TLE啊。

但是【评测记录】告诉我, TLE 了。60pts求条!

2024/10/15 12:54
加载中...