QOJ.ac
QOJ
ID | Problem | Submitter | Result | Time | Memory | Language | File size | Submit time | Judge time |
---|---|---|---|---|---|---|---|---|---|
#384033 | #6545. Connect the Dots | waretle | WA | 1ms | 6012kb | C++14 | 1.3kb | 2024-04-09 20:09:37 | 2024-04-09 20:09:37 |
Judging History
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();
}
Details
Tip: Click on the bar to expand more detailed information
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.