UOJ Logo

NOI.AC

ID题目提交者结果用时内存语言文件大小提交时间测评时间
#210228#3776. 可爱小树MarioWeng100326ms4364kbC++11649b2024-08-06 09:28:242024-08-06 12:19:17

answer

#include<bits/stdc++.h>
using namespace std;
struct d{
	int x,id,f;
}a[200005];
bool cmp(d x,d y){
	return x.x>y.x;
}
bool gy(d x,d y){
	return x.id<y.id;
}
int n,h[200005],jh[200005];
int main(){
	cin>>n;
	for(int i=1;i<=n;i++){
		cin>>a[i].x;
		a[i].id=i;
	}
	sort(a+1,a+n+1,cmp);
	h[a[1].x]=a[1].id;
	jh[a[1].x]=1;
	for(int i=2;i<=n;i++){
		a[i].f=h[a[i].x+1];
		if(!jh[a[i].x]){
			h[a[i].x]=a[i].id; 
			jh[a[i].x]=i;
		}
		if(a[jh[a[i].x+1]].x==a[jh[a[i].x+1]+1].x){
			h[a[i].x+1]=a[++jh[a[i].x+1]].id;
			//偏移
		}
	}
	sort(a+1,a+n+1,gy);
	for(int i=1;i<=n;i++){
		cout<<a[i].f<<" ";
	}
	return 0;
}

详细

小提示:点击横条可展开更详细的信息

Test #1:

score: 10
Accepted
time: 0ms
memory: 1224kb

input:

11
0 1 2 3 4 5 6 7 8 9 10

output:

2 3 4 5 6 7 8 9 10 11 0 

result:

ok Congrats, all the answers are valid.

Test #2:

score: 10
Accepted
time: 0ms
memory: 1220kb

input:

49
0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35...

output:

2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 ...

result:

ok Congrats, all the answers are valid.

Test #3:

score: 10
Accepted
time: 0ms
memory: 1244kb

input:

999
0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 3...

output:

2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 ...

result:

ok Congrats, all the answers are valid.

Test #4:

score: 10
Accepted
time: 0ms
memory: 1232kb

input:

94
0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 1 0 0 0 0 0 0 0 0 0...

output:

40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 4...

result:

ok Congrats, all the answers are valid.

Test #5:

score: 10
Accepted
time: 64ms
memory: 3568kb

input:

199992
0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0...

output:

126 126 126 126 126 126 126 126 126 126 126 126 126 126 126 126 126 126 126 126 126 126 126 126 126 ...

result:

ok Congrats, all the answers are valid.

Test #6:

score: 10
Accepted
time: 3ms
memory: 1308kb

input:

4995
3598 702 2058 315 810 3553 2897 812 3108 395 847 1936 1347 3112 431 3546 1213 542 1674 253 1115...

output:

2636 2979 802 3417 4644 2412 919 963 3271 2780 3783 1193 1481 4128 1613 2471 3761 2751 3933 535 3842...

result:

ok Congrats, all the answers are valid.

Test #7:

score: 10
Accepted
time: 118ms
memory: 4364kb

input:

199995
73857 87223 9127 55593 79096 29256 65222 68517 94617 24795 59461 64589 29004 18418 90863 2720...

output:

192292 13049 88363 9987 114466 5342 87219 130949 94970 120845 47849 118090 60208 183349 80490 156518...

result:

ok Congrats, all the answers are valid.

Test #8:

score: 10
Accepted
time: 54ms
memory: 2940kb

input:

99993
53106 38032 8196 3041 65305 15449 52233 7617 6543 21376 61968 23032 33290 58751 14610 5174 727...

output:

76798 83725 23970 88585 32587 82824 50181 16983 96022 42034 2598 73161 65147 31146 98480 11045 96825...

result:

ok Congrats, all the answers are valid.

Test #9:

score: 10
Accepted
time: 55ms
memory: 2844kb

input:

99998
37562 29469 5433 30712 31359 56582 18039 29636 52142 9885 6407 11263 47450 45300 34612 31399 1...

output:

15103 98273 63343 58792 30297 87736 65607 94123 12900 56078 33568 14718 66778 50524 97104 17330 2956...

result:

ok Congrats, all the answers are valid.

Test #10:

score: 10
Accepted
time: 32ms
memory: 2144kb

input:

49994
43071 40142 37165 42661 2289 25114 35938 2629 12203 3996 18305 7586 22898 12631 36647 17835 39...

output:

4679 37096 20436 16172 502 34949 22293 22585 2704 2755 45020 28352 46357 23659 43770 49003 13544 385...

result:

ok Congrats, all the answers are valid.

Extra Test:

score: 0
Extra Test Passed