QOJ.ac
QOJ
ID | Problem | Submitter | Result | Time | Memory | Language | File size | Submit time | Judge time |
---|---|---|---|---|---|---|---|---|---|
#376335 | #6545. Connect the Dots | schrodingerstom | WA | 1ms | 5988kb | C++14 | 3.1kb | 2024-04-04 08:03:11 | 2024-04-04 08:03:13 |
Judging History
answer
#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
typedef unsigned long long ull;
bool memBeg;
template<typename T,typename TT> void chkmin(T &x,TT y) {if(x>y) x=y;}
template<typename T,typename TT> void chkmax(T &x,TT y) {if(x<y) x=y;}
constexpr int mod=998244353;
void inc(int &x,int y) {x+=y; x-=(x>=mod)*mod;}
void dec(int &x,int y) {x-=y; x+=(x<0)*mod;}
constexpr int add(int x,int y) {return (x+y>=mod)?x+y-mod:x+y;}
constexpr int sub(int x,int y) {return (x<y)?x-y+mod:x-y;}
constexpr int quick_pow(int x,ll times,int ret=1) {
for(;times;times>>=1,x=1ll*x*x%mod) if(times&1) ret=1ll*ret*x%mod;
return ret;
}
constexpr int maxn=2e5+5;
constexpr int maxm=2e5+5;
int n,m,a[maxn],ppre[maxn],pnxt[maxn],occ[maxm];
queue<int> cand;
bool alive[maxn];
vector<pair<int,int>> plan;
void mian() {
scanf("%d%d",&n,&m);
for(int i=1;i<=n;i++) scanf("%d",&a[i]);
memset(occ,0,sizeof(int)*(m+1));
iota(ppre+1,ppre+n+2,0);
iota(pnxt,pnxt+n+1,1);
for(int i=1;i<=n;i++) occ[a[i]]++;
while(!cand.empty()) cand.pop();
int ret=0;
plan.clear();
for(int i=1;i<n;i++) if(a[i]!=a[i+1]) {
ret++; plan.emplace_back(i,i+1);
}
for(int i=2;i<n;i++) if(a[i-1]!=a[i+1]) cand.emplace(i);
fill(alive,alive+n+1,true);
int rst=n;
while(rst>2) {
while(!cand.empty()) {
int cur=cand.front();
// printf("cur = %d, alive = %d, ppre = %d, pnxt = %d\n",cur,alive[cur],ppre[cur],pnxt[cur]);
cand.pop();
if(!alive[cur]||a[ppre[cur]]==a[pnxt[cur]]) continue;
// printf("cur = %d\n",cur);
if(occ[a[cur]]==1) {
ret+=rst-3+(a[1]!=a[n]);
for(int i=pnxt[cur];i!=n;i=pnxt[i]) {
plan.emplace_back(ppre[i],pnxt[i]);
}
for(int i=ppre[cur];i!=1;i=ppre[i]) {
plan.emplace_back(ppre[i],pnxt[i]);
}
if(a[1]!=a[n]) plan.emplace_back(1,n);
rst=0; break;
}
alive[cur]=false; ret++; rst--; occ[a[cur]]--;
plan.emplace_back(ppre[cur],pnxt[cur]);
pnxt[ppre[cur]]=pnxt[cur];
ppre[pnxt[cur]]=ppre[cur];
// printf("cur = %d, pnxt = %d, ppre = %d\n",cur,pnxt[cur],ppre[cur]);
if(pnxt[cur]!=n&&a[ppre[cur]]!=a[pnxt[pnxt[cur]]]) cand.emplace(pnxt[cur]);
if(ppre[cur]!=1&&a[ppre[ppre[cur]]]!=a[pnxt[cur]]) cand.emplace(ppre[cur]);
}
if(--rst<=2) break;
alive[pnxt[1]]=false; occ[a[pnxt[1]]]--;
ppre[pnxt[pnxt[1]]]=1;
pnxt[1]=pnxt[pnxt[1]];
// printf("pnxt[pnxt[1] = %d] = %d\n",pnxt[1],pnxt[pnxt[1]]);
if(a[1]!=a[pnxt[pnxt[1]]]) cand.emplace(pnxt[1]);
}
printf("%d\n",ret);
for(auto v:plan) printf("%d %d\n",v.first,v.second);
}
bool memEn;
void fl() {
freopen(".in","r",stdin);
freopen(".out","w",stdout);
}
int main() {
fprintf(stderr,"%.24lf\n",fabs(&memEn-&memBeg)/1024.0/1024.0);
// fl();
int _; scanf("%d",&_);
while(_--) mian();
return 0;
}
Details
Tip: Click on the bar to expand more detailed information
Test #1:
score: 100
Accepted
time: 0ms
memory: 4080kb
input:
3 4 2 1 1 2 2 4 2 1 2 1 2 3 3 1 2 3
output:
3 2 3 1 3 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: 1ms
memory: 5920kb
input:
1 2 2 1 2
output:
1 1 2
result:
ok all 1 test passed
Test #3:
score: 0
Accepted
time: 0ms
memory: 3880kb
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 1 3 3 5 5 1 2 2 3 3 4 3 5 1 5 4 3 4 4 5 2 4 1 4 5 1 2 3 4 4 5 1 3 1 5 4 1 2 3 4 1 3 3 5 4 3 4 2 4 2 5 1 5 5 2 3 3 4 4 5 1 3 1 5 4 1 2 4 5 1 3 3 5
result:
ok all 10 test passed
Test #4:
score: 0
Accepted
time: 1ms
memory: 5988kb
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 2 4 4 6 1 6 8 2 3 3 4 4 5 5 6 6 7 1 3 1 5 1 7 7 2 3 4 5 5 6 1 3 1 4 5 7 1 7 6 3 4 5 6 2 4 2 5 5 7 1 5 7 1 2 3 4 4 5 6 7 1 3 4 6 1 6 7 1 2 2 3 6 7 2 4 5 7 2 5 1 7 7 1 2 2 3 3 4 3 5 3 6 3 7 1 7 8 2 3 3 4 4 5 5 6 6 7 1 3 1 5 1 7 7 1 2 3 4 4 5 5 6 1 3 5 7 1 5 7 2 3 3 4 4 5 6 7 1 3 4 6 ...
result:
ok all 10 test passed
Test #5:
score: 0
Accepted
time: 0ms
memory: 3888kb
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 2 4 5 7 1 4 1 7 1 9 9 1 2 2 3 4 5 8 9 2 4 4 6 7 9 4 7 1 7 11 1 2 2 3 3 4 5 6 6 7 7 8 8 9 3 5 1 5 1 7 1 9 9 2 3 3 4 7 8 1 3 3 5 6 8 6 9 3 6 1 9 10 2 3 4 5 5 6 6 7 7 8 1 3 1 4 7 9 1 6 1 9 9 2 3 3 4 4 5 5 6 1 3 5 7 5 8 5 9 1 5 10 2 3 5 6 6 7 7 8 8 9 1 3 1 4 4 6 1 7 1 9 9 2 3 3 4 ...
result:
ok all 10 test passed
Test #6:
score: 0
Accepted
time: 0ms
memory: 5916kb
input:
1 5 2 1 1 2 2 1
output:
4 2 3 4 5 1 3 1 4
result:
ok all 1 test passed
Test #7:
score: 0
Accepted
time: 0ms
memory: 5840kb
input:
1 7 2 2 1 1 2 1 1 2
output:
7 1 2 3 4 4 5 6 7 1 3 4 6 1 6
result:
ok all 1 test passed
Test #8:
score: 0
Accepted
time: 0ms
memory: 5864kb
input:
1 9 2 2 1 1 2 1 1 1 2 2
output:
9 1 2 3 4 4 5 7 8 1 3 4 6 6 8 6 9 1 6
result:
ok all 1 test passed
Test #9:
score: 0
Accepted
time: 0ms
memory: 4084kb
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 1 3 6 8 9 11 12 14 12 15 15 17 15 18 18 20 9 12 1 5 1 8 1 12 1 18 23 1 2 2 3 5 6 7 8 10 11 11 12 15 16 16 17 18 19 19 20 2 4 4 6 4 7 7 9 9 11 11 13 14 16 16 18 11 14 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 1 3 1 4 4 6 6 ...
result:
ok all 4 test passed
Test #10:
score: 0
Accepted
time: 0ms
memory: 5864kb
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: 1ms
memory: 5964kb
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: 3952kb
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 1 3 ...
result:
ok all 1 test passed
Test #13:
score: 0
Accepted
time: 0ms
memory: 3900kb
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 2 4 2 5 12 14 12 15 22 24 22 25 32 34 32 35 42 44 42 45 52 54 52 55 62 64 62 65 72 74 72 75 82 84 82 85 92 94 92 95 102 104 102 105 112 114 112 115 122 124 12...
result:
ok all 1 test passed
Test #14:
score: -100
Wrong Answer
time: 1ms
memory: 5836kb
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 1 3 1 4 5 7 1 5 1 7 9 1 2 2 3 4 5 5 6 6 7 1 3 1 4 4 6 1 6 9 1 2 2 3 4 5 5 6 6 7 2 4 3 5 4 6 5 7 10 1 2 2 3 3 4 4 5 5 6 6 7 2 4 2 5 2 6 1 6
result:
wrong answer TC #3: wire should connect two houses using different company.