QOJ.ac

QOJ

ID题目提交者结果用时内存语言文件大小提交时间测评时间
#738511#9733. Heavy-light Decompositionqianchen06#AC ✓21ms6040kbC++142.0kb2024-11-12 19:14:472024-11-12 19:14:51

Judging History

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

  • [2024-11-12 19:14:51]
  • 评测
  • 测评结果:AC
  • 用时:21ms
  • 内存:6040kb
  • [2024-11-12 19:14:47]
  • 提交

answer

#include <bits/stdc++.h>
using namespace std;
#define int long long
int n, k;
const int maxn = 1e5 + 10;
pair<int, int> a[maxn];
int fa[maxn];

void solve()
{
    cin >> n >> k;
    for (int i = 1; i <= k; i++)
    {
        cin >> a[i].first >> a[i].second;
    }
    sort(a + 1, a + 1 + k, [](pair<int, int> &a, pair<int, int> &b)
         { return a.second - a.first > b.second - b.first; });
    map<int, int> mp;
    int fax = 0;
    int ffx = -1;
    int sizfax = 0;
    int sizffx = 0;
    for (int i = 1; i <= 1; i++)
    {

        for (int l = a[i].first; l <= a[i].second; l++)
        {
            if (l == a[i].first)
            {
                fax = l;
                fa[l] = 0;
            }
            else
            {
                fa[l] = l - 1;
            }
        }
        if (a[i].second > a[i].first)
        {
            ffx = a[i].first + 1;
        }
        sizfax = a[i].second - a[i].first;
        sizffx = a[i].second - a[i].first - 1;
    }
    for (int i = k; i > 1; i--)
    {
        int cnt = 0;
        for (int l = a[i].first; l <= a[i].second; l++)
        {
            cnt++;
            if (l == a[i].first)
            {
                fa[l] = 0;
            }
            else
            {
                fa[l] = l - 1;
            }
        }
        if (ffx != -1 && sizffx >= cnt)
        {
            sizfax += cnt;
            fa[a[i].first] = ffx;
        }
        else
        {
            if (cnt <= sizfax)
            {
                fa[a[i].first] = fax;
            }
            else
            {
                cout << "IMPOSSIBLE\n";
                return;
            }
        }
    }
    for (int i = 1; i <= n; i++)
        cout << fa[i] << ' ';
    cout << '\n';
}

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

这程序好像有点Bug,我给组数据试试?

详细

Test #1:

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

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 2 2 7 2 9 10 2 
2 0 2 2 
IMPOSSIBLE

result:

ok Correct. (3 test cases)

Test #2:

score: 0
Accepted
time: 2ms
memory: 4288kb

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:

ok Correct. (10 test cases)

Test #3:

score: 0
Accepted
time: 4ms
memory: 4200kb

input:

5
11 5
1 3
4 6
7 8
9 10
11 11
39998 4
1 10000
10001 20000
20001 30000
30001 39998
49000 5
1 10000
39999 49000
10001 20000
20001 30000
30001 39998
16 5
1 1
2 3
4 6
7 11
12 16
10 5
1 2
3 4
5 6
7 8
9 10

output:

0 1 2 1 4 5 1 7 1 9 2 
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...

result:

ok Correct. (5 test cases)

Test #4:

score: 0
Accepted
time: 12ms
memory: 3828kb

input:

10000
20 6
17 20
7 9
1 3
4 6
10 12
13 16
20 12
7 7
4 4
10 10
8 8
3 3
1 1
6 6
2 2
5 5
11 11
12 20
9 9
20 16
11 11
5 6
9 9
2 2
12 12
1 1
18 20
8 8
15 15
13 13
16 17
10 10
14 14
3 3
4 4
7 7
20 16
6 7
10 10
13 13
18 18
19 19
14 14
1 1
20 20
8 8
4 5
9 9
2 3
12 12
11 11
16 17
15 15
20 5
1 1
6 6
7 12
13 20...

output:

IMPOSSIBLE
13 13 13 13 13 13 13 13 13 13 13 0 12 13 14 15 16 17 18 19 
19 19 19 19 18 5 19 19 19 19 19 19 19 19 19 18 16 0 18 19 
IMPOSSIBLE
14 14 2 3 4 14 14 7 8 9 10 11 0 13 14 15 16 17 18 19 
IMPOSSIBLE
10 10 2 3 4 5 6 7 0 9 10 11 12 13 14 15 16 17 18 19 
11 1 2 3 11 5 6 7 11 0 10 11 12 13 14 15 ...

result:

ok Correct. (10000 test cases)

Test #5:

score: 0
Accepted
time: 14ms
memory: 5612kb

input:

20000
13 12
12 12
7 7
1 1
5 5
9 9
8 8
13 13
4 4
3 3
6 6
10 11
2 2
16 8
4 4
5 5
1 1
6 6
7 7
3 3
8 16
2 2
20 17
19 19
1 1
17 18
14 14
4 4
13 13
7 7
5 5
11 11
15 15
16 16
20 20
12 12
9 10
8 8
2 3
6 6
17 9
3 4
2 2
9 10
7 8
5 6
11 12
1 1
15 17
13 14
6 2
2 6
1 1
1 1
1 1
10 2
5 10
1 4
17 17
3 3
12 12
15 15...

output:

10 10 10 10 10 10 10 10 10 0 10 10 10 
9 9 9 9 9 9 9 0 8 9 10 11 12 13 14 15 
IMPOSSIBLE
16 16 15 3 15 5 15 7 15 9 15 11 15 13 0 15 16 
3 0 2 3 4 5 
0 
6 1 2 3 0 5 6 7 8 9 
IMPOSSIBLE
0 1 2 3 4 5 6 7 8 9 10 11 12 13 
IMPOSSIBLE
IMPOSSIBLE
6 6 6 6 0 5 6 7 8 9 10 11 12 13 14 15 
0 1 
IMPOSSIBLE
IMPOSS...

result:

ok Correct. (20000 test cases)

Test #6:

score: 0
Accepted
time: 16ms
memory: 5616kb

input:

50000
1 1
1 1
4 3
1 1
4 4
2 3
9 9
1 1
5 5
8 8
9 9
7 7
2 2
3 3
6 6
4 4
4 2
1 2
3 4
2 2
1 1
2 2
1 1
1 1
10 2
1 7
8 10
8 8
4 4
5 5
6 6
8 8
3 3
1 1
2 2
7 7
7 7
7 7
4 4
5 5
2 2
3 3
1 1
6 6
10 2
8 10
1 7
8 1
1 8
2 1
1 2
9 4
1 2
5 6
7 9
3 4
7 1
1 7
7 2
1 1
2 7
4 2
1 1
2 4
6 3
3 6
1 1
2 2
3 3
3 3
1 1
2 2
1 ...

output:

0 
2 0 2 2 
IMPOSSIBLE
IMPOSSIBLE
IMPOSSIBLE
0 
0 1 2 3 4 5 6 2 8 9 
IMPOSSIBLE
IMPOSSIBLE
0 1 2 3 4 5 6 2 8 9 
0 1 2 3 4 5 6 7 
0 1 
7 1 7 3 7 5 0 7 8 
0 1 2 3 4 5 6 
3 0 2 3 4 5 6 
3 0 2 3 
4 4 0 3 4 5 
IMPOSSIBLE
0 
3 3 0 3 
IMPOSSIBLE
IMPOSSIBLE
IMPOSSIBLE
IMPOSSIBLE
0 1 
IMPOSSIBLE
0 1 1 1 
3 3...

result:

ok Correct. (50000 test cases)

Test #7:

score: 0
Accepted
time: 9ms
memory: 3856kb

input:

100
2619 693
286 286
81 81
552 552
397 397
24 24
414 414
378 378
660 660
538 538
125 125
190 190
585 585
180 180
564 564
218 218
158 158
425 425
189 189
94 94
29 29
678 678
543 543
352 352
659 659
467 467
403 403
298 298
517 517
196 196
156 156
278 278
259 259
417 417
499 499
246 246
195 195
380 380...

output:

694 694 694 694 694 694 694 694 694 694 694 694 694 694 694 694 694 694 694 694 694 694 694 694 694 694 694 694 694 694 694 694 694 694 694 694 694 694 694 694 694 694 694 694 694 694 694 694 694 694 694 694 694 694 694 694 694 694 694 694 694 694 694 694 694 694 694 694 694 694 694 694 694 694 694 ...

result:

ok Correct. (100 test cases)

Test #8:

score: 0
Accepted
time: 11ms
memory: 5312kb

input:

100
53984 965
9577 9632
53593 53648
17305 17360
40321 40376
37465 37520
45753 45808
52921 52976
21281 21336
44241 44296
17921 17976
40545 40600
7897 7952
9689 9744
32089 32144
43345 43400
46817 46872
4817 4872
24585 24640
41889 41944
36065 36120
3585 3640
1486 1540
29793 29848
8065 8120
43401 43456
...

output:

IMPOSSIBLE
IMPOSSIBLE
35754 1 2 3 4 5 35754 35754 8 35754 10 11 12 13 35754 35754 35754 35754 18 35754 35754 35754 22 35754 35754 35754 35754 35754 35754 29 30 35754 32 35754 35754 35 36 35754 35754 39 40 41 42 43 44 45 46 47 35754 49 35754 35754 35754 35754 54 55 56 35754 58 59 35754 35754 62 63 64...

result:

ok Correct. (100 test cases)

Test #9:

score: 0
Accepted
time: 21ms
memory: 6040kb

input:

2
100000 72281
52926 52926
1645 1646
33266 33266
88480 88480
16983 16983
29975 29977
32528 32528
89186 89186
5810 5810
90512 90512
8859 8859
22671 22671
51648 51649
26506 26506
99017 99018
64526 64526
61453 61454
73914 73914
27338 27339
43510 43510
22298 22300
59714 59714
64394 64395
71955 71956
481...

output:

28437 28437 2 3 28437 28437 28437 7 28437 28437 10 11 28437 28437 28437 28437 16 28437 18 19 20 28437 28437 23 24 28437 26 28437 28437 28437 28437 28437 28437 28437 28437 28437 36 28437 38 39 28437 28437 28437 28437 28437 45 28437 47 28437 49 50 28437 28437 28437 28437 28437 28437 28437 28437 28437 ...

result:

ok Correct. (2 test cases)

Test #10:

score: 0
Accepted
time: 15ms
memory: 3604kb

input:

100000
2 1
1 2
2 1
1 2
2 2
2 2
1 1
2 2
2 2
1 1
2 2
1 1
2 2
2 2
2 2
1 1
2 2
1 1
2 2
2 2
1 1
2 2
2 2
1 1
2 2
2 2
2 2
1 1
2 2
2 2
1 1
2 2
1 1
2 2
2 2
1 1
2 2
2 2
2 2
1 1
2 1
1 2
2 2
2 2
1 1
2 2
2 2
1 1
2 2
2 2
1 1
2 1
1 2
2 2
1 1
2 2
2 2
1 1
2 2
2 1
1 2
2 2
2 2
1 1
2 2
2 2
1 1
2 2
1 1
2 2
2 1
1 2
2 2
1...

output:

0 1 
0 1 
IMPOSSIBLE
IMPOSSIBLE
IMPOSSIBLE
IMPOSSIBLE
IMPOSSIBLE
IMPOSSIBLE
IMPOSSIBLE
IMPOSSIBLE
IMPOSSIBLE
IMPOSSIBLE
IMPOSSIBLE
IMPOSSIBLE
0 1 
IMPOSSIBLE
IMPOSSIBLE
IMPOSSIBLE
0 1 
IMPOSSIBLE
IMPOSSIBLE
0 1 
IMPOSSIBLE
IMPOSSIBLE
IMPOSSIBLE
0 1 
IMPOSSIBLE
IMPOSSIBLE
IMPOSSIBLE
IMPOSSIBLE
IMPOSS...

result:

ok Correct. (100000 test cases)

Test #11:

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

input:

100000
1 1
1 1
1 1
1 1
1 1
1 1
1 1
1 1
1 1
1 1
1 1
1 1
1 1
1 1
1 1
1 1
1 1
1 1
1 1
1 1
1 1
1 1
1 1
1 1
1 1
1 1
1 1
1 1
1 1
1 1
1 1
1 1
1 1
1 1
1 1
1 1
1 1
1 1
1 1
1 1
1 1
1 1
1 1
1 1
1 1
1 1
1 1
1 1
1 1
1 1
1 1
1 1
1 1
1 1
1 1
1 1
1 1
1 1
1 1
1 1
1 1
1 1
1 1
1 1
1 1
1 1
1 1
1 1
1 1
1 1
1 1
1 1
1 1
1...

output:

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 
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 
0 
0 
0 
0 
0 
0 
...

result:

ok Correct. (100000 test cases)

Test #12:

score: 0
Accepted
time: 21ms
memory: 3624kb

input:

100000
2 1
1 2
3 1
1 3
5 2
1 1
2 5
4 4
2 2
4 4
3 3
1 1
3 3
1 1
3 3
2 2
5 1
1 5
1 1
1 1
3 2
1 1
2 3
5 5
5 5
2 2
3 3
4 4
1 1
3 3
3 3
1 1
2 2
5 4
3 4
1 1
2 2
5 5
4 3
2 2
1 1
3 4
1 1
1 1
4 1
1 4
5 4
3 4
2 2
1 1
5 5
3 1
1 3
3 3
1 1
3 3
2 2
5 1
1 5
1 1
1 1
2 2
2 2
1 1
5 1
1 5
1 1
1 1
2 2
2 2
1 1
4 2
4 4
1...

output:

0 1 
0 1 2 
3 0 2 3 4 
IMPOSSIBLE
IMPOSSIBLE
0 1 2 3 4 
0 
2 0 2 
IMPOSSIBLE
IMPOSSIBLE
3 3 0 3 3 
3 3 0 3 
0 
0 1 2 3 
3 3 0 3 3 
0 1 2 
IMPOSSIBLE
0 1 2 3 4 
0 
IMPOSSIBLE
0 1 2 3 4 
0 
IMPOSSIBLE
0 1 2 2 
4 4 0 3 4 
0 1 1 
IMPOSSIBLE
IMPOSSIBLE
0 
3 1 0 3 4 
0 
IMPOSSIBLE
4 4 0 3 4 
0 1 2 
3 3 0 ...

result:

ok Correct. (100000 test cases)

Test #13:

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

input:

5000
50 26
5 6
9 10
1 1
23 24
43 44
19 20
29 30
2 2
17 18
47 48
3 4
35 36
27 28
25 26
49 50
31 32
45 46
15 16
39 40
21 22
11 12
13 14
37 38
33 34
7 8
41 42
86 12
17 20
33 36
41 86
1 3
4 6
13 16
25 28
37 40
29 32
21 24
7 9
10 12
59 35
5 5
6 6
22 22
31 31
32 32
25 25
21 21
20 20
26 26
2 2
34 34
3 3
35...

output:

IMPOSSIBLE
42 1 2 42 4 5 42 7 8 42 10 11 42 13 14 15 42 17 18 19 42 21 22 23 42 25 26 27 42 29 30 31 42 33 34 35 42 37 38 39 0 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 
36 36 36 36 36 36 36 36 36 36 36 36 3...

result:

ok Correct. (5000 test cases)

Test #14:

score: 0
Accepted
time: 12ms
memory: 5556kb

input:

5000
335 22
13 18
134 140
85 91
50 56
7 12
31 36
113 119
71 77
106 112
1 6
37 42
64 70
92 98
43 49
120 126
127 133
99 105
25 30
141 335
19 24
57 63
78 84
475 21
40 42
22 24
37 39
16 18
7 9
31 33
49 51
43 45
52 54
19 21
1 2
55 57
10 12
5 6
58 475
28 30
13 15
25 27
34 36
3 4
46 48
252 159
138 138
77 7...

output:

142 1 2 3 4 5 142 7 8 9 10 11 142 13 14 15 16 17 142 19 20 21 22 23 142 25 26 27 28 29 142 31 32 33 34 35 142 37 38 39 40 41 142 43 44 45 46 47 48 142 50 51 52 53 54 55 142 57 58 59 60 61 62 142 64 65 66 67 68 69 142 71 72 73 74 75 76 142 78 79 80 81 82 83 142 85 86 87 88 89 90 142 92 93 94 95 96 97...

result:

ok Correct. (5000 test cases)

Test #15:

score: 0
Accepted
time: 5ms
memory: 3592kb

input:

1000
89 19
17 18
7 8
11 12
1 1
27 28
35 89
13 14
15 16
25 26
9 10
31 32
3 4
33 34
29 30
19 20
23 24
5 6
21 22
2 2
962 187
886 890
361 365
376 380
766 770
901 905
181 185
626 630
921 925
86 90
416 420
281 285
506 510
171 175
41 45
776 780
441 445
491 495
341 345
631 635
141 145
356 360
891 895
231 23...

output:

36 36 36 3 36 5 36 7 36 9 36 11 36 13 36 15 36 17 36 19 36 21 36 23 36 25 36 27 36 29 36 31 36 33 0 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 
927 1 2 3 927 5 6 7 927 9 10 11 927 1...

result:

ok Correct. (1000 test cases)

Test #16:

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

input:

500
4037 286
1756 1768
2770 2782
3095 3107
1405 1417
2705 2717
2913 2925
1847 1859
482 494
807 819
2744 2756
2822 2834
2276 2288
3238 3250
1106 1118
2055 2067
3056 3068
2328 2340
2146 2158
1249 1261
1015 1027
2224 2236
1613 1625
1717 1729
222 234
3329 3341
1795 1807
2354 2366
37 48
3082 3094
2068 20...

output:

3694 1 2 3 4 5 6 7 8 9 10 11 3694 13 14 15 16 17 18 19 20 21 22 23 3694 25 26 27 28 29 30 31 32 33 34 35 3694 37 38 39 40 41 42 43 44 45 46 47 3694 49 50 51 52 53 54 55 56 57 58 59 3694 61 62 63 64 65 66 67 68 69 70 71 3694 73 74 75 76 77 78 79 80 81 82 83 3694 85 86 87 88 89 90 91 92 93 94 95 3694 ...

result:

ok Correct. (500 test cases)

Extra Test:

score: 0
Extra Test Passed