QOJ.ac

QOJ

IDProblemSubmitterResultTimeMemoryLanguageFile sizeSubmit timeJudge time
#745013#9733. Heavy-light Decompositionshenchuan_fanWA 2ms3676kbC++201.5kb2024-11-14 01:22:212024-11-14 01:22:21

Judging History

你现在查看的是最新测评结果

  • [2024-11-14 01:22:21]
  • 评测
  • 测评结果:WA
  • 用时:2ms
  • 内存:3676kb
  • [2024-11-14 01:22:21]
  • 提交

answer

#include<bits/stdc++.h>

using namespace std;

typedef pair<int,int>PII;

void solve() {
	int n,m;
	cin>>n>>m;
	vector<PII>res;
	vector<int>fa(n+1,0);
	for(int i=1; i<=m; i++) {
		int l,r;
		cin>>l>>r;
		res.push_back({l,r});
		for(int j=l+1; j<=r; j++) {
			fa[j]=j-1;
		}
	}
	sort(res.begin(),res.end(),[&](auto &A,auto &B)->bool {
		return (A.second-A.first)>(B.second-B.first);
	});
	if(m==1) {
		for(int i=1; i<=n; i++) {
			cout<<fa[i]<<' ';
		}
		cout<<'\n';
	} else {
		if(res[0].second-res[0].first==res[1].second-res[1].first) {
			if(res[0].second-res[0].first==0||res[0].second-res[0].first==1) {
				cout<<"IMPOSSIBLE"<<'\n';
			} else {
				int pos=0;
				for(int i=2; i<m; i++) {
					if(res[i].second-res[i].first<res[0].second-res[0].first) {
						pos=i;
						break;
					}
				}
				if(pos==0){
					cout<<"IMPOSSIBLE"<<'\n';
					return ;
				}
				int len=res[pos].second-res[pos].first+1;
				fa[res[pos].first]=res[0].second-len;
				int p=res[0].first;
				for(int i=1; i<m; i++) {
					if(i==pos)	continue;
					fa[res[i].first]=p;
				}
				for(int i=1; i<=n; i++) {
					cout<<fa[i]<<' ';
				}
				cout<<'\n';
			}
		} else {
			int p=res[0].first;
			for(int i=1; i<m; i++) {
				fa[res[i].first]=p;
			}
			for(int i=1; i<=n; i++) {
				cout<<fa[i]<<' ';
			}
			cout<<'\n';
		}
	}

}

int main() {
	ios::sync_with_stdio(false),cin.tie(0),cout.tie(0);
	int T=1;
	cin>>T;
	while(T--) {
		solve();
	}
	return 0;
}

Details

Tip: Click on the bar to expand more detailed information

Test #1:

score: 100
Accepted
time: 0ms
memory: 3568kb

input:

3
12 5
1 5
9 11
7 8
6 6
12 12
4 3
1 1
4 4
2 3
2 2
1 1
2 2

output:

0 1 2 3 4 1 1 7 1 9 10 1 
2 0 2 2 
IMPOSSIBLE

result:

ok Correct. (3 test cases)

Test #2:

score: -100
Wrong Answer
time: 2ms
memory: 3676kb

input:

10
1 1
1 1
100000 1
1 100000
12 4
1 3
4 6
7 9
10 12
6 3
4 6
2 3
1 1
8999 3
1 3000
3001 6000
6001 8999
14 4
1 3
4 6
7 10
11 14
17 5
1 3
4 6
7 10
11 14
15 17
19999 2
1 9999
10000 19999
1 1
1 1
5 3
1 1
2 3
4 5

output:

0 
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 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101...

result:

wrong answer 2 should be a heavy child, but the maximum one with size 3000 and 2999 found. (test case 5)