QOJ.ac

QOJ

ID题目提交者结果用时内存语言文件大小提交时间测评时间
#384033#6545. Connect the DotswaretleWA 1ms6012kbC++141.3kb2024-04-09 20:09:372024-04-09 20:09:37

Judging History

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

  • [2024-04-09 20:09:37]
  • 评测
  • 测评结果:WA
  • 用时:1ms
  • 内存:6012kb
  • [2024-04-09 20:09:37]
  • 提交

answer

#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
typedef unsigned long long ull;
const int N=2e5+5;
int n,m,a[N],st[N],tp,cnt[N];
bool del[N];
vector<pair<int,int>>ans;
void work(int x)
{
    int l=x,r=x;
    for(int i=x-1;i;--i)if(!del[i])
    {
        if(l!=x)ans.emplace_back(i,x);
        l=i;
    }
    for(int i=x+1;i<=n;++i)if(!del[i])
    {
        if(r!=x)ans.emplace_back(x,i);
        r=i;
    }
    if(a[l]!=a[r]&&l!=x&&r!=x)ans.emplace_back(l,r);
}
void solve()
{
    scanf("%d%d",&n,&m);
    for(int i=1;i<=n;++i)scanf("%d",a+i);
    memset(del,0,n+1),ans.clear(),memset(cnt,0,m+1<<2),tp=0;
    for(int i=1;i<=n;++i)++cnt[a[i]];
    for(int i=1;i<n;++i)if(a[i]!=a[i+1])ans.emplace_back(i,i+1);
    for(int i=1;i<=n;++i)
    {
        while(tp>1&&a[st[tp-1]]!=a[i])
        {
            if(cnt[a[i]]==1)
            {
                work(i);i=n+1;tp=0;break;
            }
            ans.emplace_back(i,st[tp-1]),del[st[tp]]=1,--cnt[st[tp]],--tp;
        }
        st[++tp]=i;
    }
    for(int i=4;i<=tp;i+=2)ans.emplace_back(st[1],st[i]);
    printf("%d\n",(int)ans.size());
    for(auto i:ans)printf("%d %d\n",i.first,i.second);
}
int main()
{
    int _;scanf("%d",&_);
    while(_--)solve();
}

詳細信息

Test #1:

score: 100
Accepted
time: 1ms
memory: 5968kb

input:

3
4 2
1 1 2 2
4 2
1 2 1 2
3 3
1 2 3

output:

3
2 3
3 1
1 4
4
1 2
2 3
3 4
1 4
3
1 2
2 3
1 3

result:

ok all 3 test passed

Test #2:

score: 0
Accepted
time: 0ms
memory: 3844kb

input:

1
2 2
1 2

output:

1
1 2

result:

ok all 1 test passed

Test #3:

score: 0
Accepted
time: 1ms
memory: 5948kb

input:

10
5 2
2 2 2 1 2
5 2
2 1 2 1 2
5 2
1 2 2 2 1
5 2
2 1 2 1 1
5 2
1 1 1 2 1
5 2
1 2 2 1 2
5 2
2 1 1 2 2
5 2
2 2 2 1 1
5 2
1 1 2 1 2
5 2
1 2 2 2 1

output:

4
3 4
4 5
2 4
1 4
5
1 2
2 3
3 4
4 5
1 4
4
1 2
4 5
3 1
4 1
5
1 2
2 3
3 4
5 3
1 5
4
3 4
4 5
2 4
1 4
5
1 2
3 4
4 5
3 1
1 5
4
1 2
3 4
3 1
5 3
4
3 4
4 2
4 1
5 1
5
2 3
3 4
4 5
3 1
1 5
4
1 2
4 5
3 1
4 1

result:

ok all 10 test passed

Test #4:

score: 0
Accepted
time: 1ms
memory: 5912kb

input:

10
7 2
1 2 1 1 1 2 1
7 2
1 1 2 1 2 1 2
7 2
2 2 1 1 2 1 1
7 2
1 1 1 2 2 1 1
7 2
1 2 2 1 2 2 1
7 2
2 1 2 2 2 2 1
7 2
1 2 1 2 2 2 2
7 2
2 2 1 2 1 2 1
7 2
2 1 1 2 1 2 2
7 2
2 2 1 2 1 1 2

output:

7
1 2
2 3
5 6
6 7
4 2
5 2
1 6
8
2 3
3 4
4 5
5 6
6 7
3 1
1 5
1 7
7
2 3
4 5
5 6
3 1
4 1
7 5
1 7
6
3 4
5 6
4 2
4 1
1 5
5 7
7
1 2
3 4
4 5
6 7
3 1
6 4
1 6
7
1 2
2 3
6 7
4 2
5 2
6 2
1 7
7
1 2
2 3
3 4
5 3
6 3
7 3
1 7
8
2 3
3 4
4 5
5 6
6 7
3 1
1 5
1 7
7
1 2
3 4
4 5
5 6
3 1
7 5
1 5
7
2 3
3 4
4 5
6 7
3 1
6 4
...

result:

ok all 10 test passed

Test #5:

score: 0
Accepted
time: 1ms
memory: 5972kb

input:

10
9 2
1 1 1 2 1 2 2 1 2
9 2
1 2 1 1 2 2 2 2 1
9 2
2 1 2 1 1 2 1 2 1
9 2
1 1 2 1 1 1 1 2 2
9 2
1 1 2 2 1 2 1 2 2
9 2
2 2 1 2 1 2 2 2 2
9 2
1 1 2 2 2 1 2 1 2
9 2
1 1 2 1 1 2 2 2 2
9 2
1 1 1 1 2 1 1 2 1
9 2
2 1 2 2 1 1 2 2 1

output:

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

result:

ok all 10 test passed

Test #6:

score: 0
Accepted
time: 1ms
memory: 5868kb

input:

1
5 2
1 1 2 2 1

output:

4
2 3
4 5
3 1
1 4

result:

ok all 1 test passed

Test #7:

score: 0
Accepted
time: 0ms
memory: 3968kb

input:

1
7 2
2 1 1 2 1 1 2

output:

7
1 2
3 4
4 5
6 7
3 1
6 4
1 6

result:

ok all 1 test passed

Test #8:

score: 0
Accepted
time: 1ms
memory: 3908kb

input:

1
9 2
2 1 1 2 1 1 1 2 2

output:

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

result:

ok all 1 test passed

Test #9:

score: 0
Accepted
time: 0ms
memory: 3836kb

input:

4
20 2
2 1 1 2 1 2 1 1 2 1 1 1 1 2 2 2 1 1 2 2
20 2
2 1 2 2 2 1 1 2 2 2 1 2 2 2 2 1 2 2 1 2
20 2
2 2 1 1 2 2 1 1 1 1 1 2 1 1 2 2 1 2 1 1
20 2
2 1 2 2 2 1 2 2 1 1 1 2 1 2 2 1 2 1 1 2

output:

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

result:

ok all 4 test passed

Test #10:

score: 0
Accepted
time: 0ms
memory: 3792kb

input:

4
100 2
2 2 2 1 2 1 1 1 1 2 2 1 2 2 2 1 2 2 2 2 1 1 1 2 2 1 1 2 1 1 2 1 2 2 1 1 1 2 1 2 1 1 2 1 2 1 2 1 2 1 1 1 1 2 1 1 1 2 2 2 1 2 2 2 1 1 1 2 1 2 1 2 2 1 2 2 1 1 2 1 1 1 1 2 2 1 2 1 1 2 2 1 2 2 1 2 1 2 2 2
100 2
2 1 1 1 1 1 2 2 2 1 2 1 2 2 1 2 2 1 1 1 1 2 1 1 1 2 2 1 1 2 1 1 2 1 1 2 1 1 1 1 1 2 1 ...

output:

126
3 4
4 5
5 6
9 10
11 12
12 13
15 16
16 17
20 21
23 24
25 26
27 28
28 29
30 31
31 32
32 33
34 35
37 38
38 39
39 40
40 41
42 43
43 44
44 45
45 46
46 47
47 48
48 49
49 50
53 54
54 55
57 58
60 61
61 62
64 65
67 68
68 69
69 70
70 71
71 72
73 74
74 75
76 77
78 79
79 80
83 84
85 86
86 87
87 88
89 90
91 ...

result:

ok all 4 test passed

Test #11:

score: 0
Accepted
time: 0ms
memory: 3868kb

input:

1
100 2
2 2 1 1 2 2 2 1 1 2 1 1 1 2 2 1 2 2 2 1 1 2 2 1 1 2 2 2 1 2 1 1 2 1 1 2 2 1 2 1 1 2 1 2 2 1 2 2 2 2 1 2 1 2 1 1 2 1 1 1 1 1 2 2 2 1 1 2 1 2 2 2 2 1 1 2 2 2 1 1 2 2 2 1 2 2 1 2 1 2 1 2 2 2 1 2 2 2 1 1

output:

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

result:

ok all 1 test passed

Test #12:

score: 0
Accepted
time: 0ms
memory: 6012kb

input:

1
100 2
1 2 2 1 1 2 2 1 1 2 2 1 1 2 2 1 1 2 2 1 1 2 2 1 1 2 2 1 1 2 2 1 1 2 2 1 1 2 2 1 1 2 2 1 1 2 2 1 1 2 2 1 1 2 2 1 1 2 2 1 1 2 2 1 1 2 2 1 1 2 2 1 1 2 2 1 1 2 2 1 1 2 2 1 1 2 2 1 1 2 2 1 1 2 2 1 1 2 2 1

output:

123
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
3 1
...

result:

ok all 1 test passed

Test #13:

score: 0
Accepted
time: 1ms
memory: 3920kb

input:

1
200 2
1 1 1 2 2 2 2 2 2 2 2 2 2 1 1 1 1 1 1 1 1 1 1 2 2 2 2 2 2 2 2 2 2 1 1 1 1 1 1 1 1 1 1 2 2 2 2 2 2 2 2 2 2 1 1 1 1 1 1 1 1 1 1 2 2 2 2 2 2 2 2 2 2 1 1 1 1 1 1 1 1 1 1 2 2 2 2 2 2 2 2 2 2 1 1 1 1 1 1 1 1 1 1 2 2 2 2 2 2 2 2 2 2 1 1 1 1 1 1 1 1 1 1 2 2 2 2 2 2 2 2 2 2 1 1 1 1 1 1 1 1 1 1 2 2 2 ...

output:

208
3 4
13 14
23 24
33 34
43 44
53 54
63 64
73 74
83 84
93 94
103 104
113 114
123 124
133 134
143 144
153 154
163 164
173 174
183 184
193 194
4 2
4 1
5 1
6 1
7 1
8 1
9 1
10 1
11 1
12 1
13 1
15 13
16 13
17 13
18 13
19 13
20 13
21 13
22 13
23 13
25 23
26 23
27 23
28 23
29 23
30 23
31 23
32 23
33 23
35...

result:

ok all 1 test passed

Test #14:

score: -100
Wrong Answer
time: 0ms
memory: 3972kb

input:

4
7 3
2 2 3 1 3 1 1
7 3
3 1 2 2 3 1 3
7 3
2 1 3 3 2 3 2
7 3
3 2 3 1 3 1 3

output:

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

result:

wrong answer output = 8, answer = 9.