QOJ.ac

QOJ

IDProblemSubmitterResultTimeMemoryLanguageFile sizeSubmit timeJudge time
#788540#6502. Disjoint Set UnionOIer_kzc#TL 313ms18112kbC++202.9kb2024-11-27 17:22:212024-11-27 17:22:21

Judging History

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

  • [2024-11-27 17:22:21]
  • 评测
  • 测评结果:TL
  • 用时:313ms
  • 内存:18112kb
  • [2024-11-27 17:22:21]
  • 提交

answer

#include<bits/stdc++.h>
using namespace std;
#define endl '\n'
#define dbg(x) cerr<<"In Line "<<__LINE__<<' '<<#x<<" = "<<(x)<<endl
int f[1005],g[1005],fa[1005],dag[1005],deg[1005],n;
bool yes[1005],to[1005][1005];
vector<int> v[1005];
#define eb emplace_back
int find(int x){
    if(f[x]==x) return x;
    return find(f[x]);
}
int gind(int x){
    if(g[x]==x) return x;
    return gind(g[x]);
}
int Find(int x){
    if(f[x]==x) return x;
    return f[x]=Find(f[x]);
}
bool check(){
    for(int i=1;i<=n;i++) if(f[i]==g[i]) return 1;return 0;
}
struct node{
    int t,x,y;
}q[2000005];
bool is[1005];
int main(){
    int t;cin>>t;
    while(t--){
        cin>>n;
        for(int i=1;i<=n;i++){
            yes[i]=deg[i]=0;
            for(int j=1;j<=n;j++) to[i][j]=0;
        }
        for(int i=1;i<=n;i++) cin>>f[i],yes[i]=f[i]==i;
        bool no=0;
        for(int i=1;i<=n;i++){
            cin>>g[i];
            if(g[i]==i&&!yes[g[i]]&&!no){
                cout<<"NO\n",no=1;
            }
        }
        if(no) continue;
        for(int i=1;i<=n;i++) if(f[i]^g[i]&&!yes[g[i]]){
            cout<<"NO\n",no=1;break;
        }
        if(no) continue;
        for(int i=1;i<=n;i++) if(f[i]^g[i]){
            fa[i]=find(f[i]);
            if(fa[i]^g[i]&&!to[fa[i]][g[i]]) to[fa[i]][g[i]]=1,deg[g[i]]++;
        }
        for(int i=1;i<=n;i++) v[i].clear();
        for(int i=1;i<=n;i++) if(f[i]==i) v[gind(i)].eb(i);
        int tot=0;
        for(int i=1;i<=n;i++) if(g[i]==i){
            queue<int> qu;
            for(int i=1;i<=n;i++) is[i]=0;
            for(int j:v[i]){
                is[j]=1;
                if(!deg[j]) qu.emplace(j);
            }
            int tim=0;
            while(!qu.empty()){
                int f=qu.front();qu.pop();
                if(!is[f]){
                    dbg("Fuck");
                    cout<<"NO\n",no=1;break;
                }
                if(yes[f]) dag[++tim]=f;
                for(int i=1;i<=n;i++) if(to[f][i]){
                    to[f][i]=0;
                    if(!--deg[i]) qu.emplace(i);
                }
            }
            if(no) break;
            for(int j:v[i]) if(deg[j]){
                cout<<"NO\n",no=1;break;
            }
            if(no) break;
            for(int i=1;i<=tim;i++){
                int x=dag[i];
                for(int j=1;j<=n;j++) if(fa[j]==x&&f[j]^g[j]) Find(j),q[++tot]={1,j};
                if(i^tim) f[x]=dag[i+1],q[++tot]={2,x,dag[i+1]};
                for(int j=1;j<=n;j++) if(fa[j]==x&&f[j]^g[j]) Find(j),q[++tot]={1,j},fa[j]=dag[i+1];
            }
        }
        if(!no){
            if(check()){
                cout<<"YES\n"<<tot<<endl;
                for(int i=1;i<=tot;i++){
                    cout<<q[i].t<<' '<<q[i].x;
                    if(q[i].t==2) cout<<' '<<q[i].y;cout<<endl;
                }
            }
            else cout<<"NO\n";
        }
    }
}

Details

Tip: Click on the bar to expand more detailed information

Test #1:

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

input:

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

output:

YES
2
1 1
2 1 2
YES
9
1 3
1 4
2 3 2
1 3
1 4
1 2
1 3
2 2 1
1 3
YES
8
1 1
2 1 2
1 2
2 2 3
1 3
2 3 4
1 4
2 4 5
NO
YES
15
1 6
2 6 2
1 2
1 3
2 2 5
1 2
1 3
1 2
1 5
2 5 4
1 2
1 2
1 4
2 4 1
1 2

result:

ok good! (YES count = 4, NO count = 1) (5 test cases)

Test #2:

score: 0
Accepted
time: 243ms
memory: 3608kb

input:

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

output:

YES
4
1 1
1 5
2 1 2
1 5
YES
0
YES
13
1 2
2 2 3
1 2
1 2
1 3
1 5
2 3 4
1 2
1 5
1 4
1 5
2 4 1
1 5
YES
4
1 3
1 5
2 3 2
1 5
YES
0
YES
4
1 2
2 2 3
1 1
2 1 5
YES
9
1 3
2 3 1
1 2
2 2 5
1 2
1 2
1 5
2 5 4
1 2
YES
2
1 5
2 5 2
YES
2
1 2
2 2 3
YES
6
1 1
2 1 2
1 3
1 5
2 3 4
1 5
YES
2
1 1
2 1 5
YES
11
1 1
1 3
2 1 ...

result:

ok good! (YES count = 100000, NO count = 0) (100000 test cases)

Test #3:

score: 0
Accepted
time: 313ms
memory: 5552kb

input:

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

output:

YES
2
1 2
2 2 10
YES
35
1 2
1 7
2 2 3
1 2
1 7
1 2
1 3
1 7
2 3 4
1 2
1 3
1 7
1 2
1 3
1 4
1 7
2 4 5
1 2
1 3
1 4
1 7
1 2
1 3
1 4
1 5
1 7
1 8
1 9
2 5 6
1 2
1 3
1 4
1 7
1 8
1 9
YES
37
1 1
2 1 2
1 1
1 1
1 2
2 2 4
1 1
1 2
1 1
1 2
1 4
2 4 10
1 1
1 2
1 4
1 1
1 2
1 4
1 8
1 10
2 10 7
1 1
1 2
1 4
1 8
1 1
1 4
1 ...

result:

ok good! (YES count = 50000, NO count = 0) (50000 test cases)

Test #4:

score: 0
Accepted
time: 177ms
memory: 3656kb

input:

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

output:

YES
106
1 11
2 11 3
1 5
2 5 9
1 5
1 1
1 5
1 9
1 12
2 9 13
1 1
1 5
1 9
1 12
1 1
1 5
1 9
1 12
1 13
2 13 14
1 1
1 5
1 9
1 12
1 13
1 1
1 5
1 9
1 12
1 13
1 14
2 14 17
1 1
1 5
1 9
1 12
1 13
1 14
1 1
1 5
1 9
1 12
1 13
1 14
1 17
2 17 19
1 1
1 5
1 9
1 12
1 13
1 14
1 17
1 1
1 5
1 9
1 12
1 13
1 14
1 16
1 17
1 ...

result:

ok good! (YES count = 12500, NO count = 0) (12500 test cases)

Test #5:

score: 0
Accepted
time: 154ms
memory: 3648kb

input:

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

output:

YES
235
1 1
2 1 10
1 5
1 9
1 15
1 18
2 5 6
1 5
1 9
1 15
1 18
1 5
1 6
1 9
1 15
1 18
2 6 7
1 5
1 6
1 9
1 15
1 18
1 5
1 6
1 7
1 8
1 9
1 15
1 18
2 7 14
1 5
1 6
1 7
1 8
1 9
1 15
1 18
1 5
1 6
1 7
1 8
1 9
1 14
1 15
1 18
2 14 16
1 5
1 6
1 7
1 8
1 9
1 14
1 15
1 18
1 5
1 6
1 7
1 8
1 9
1 14
1 15
1 16
1 18
2 16...

result:

ok good! (YES count = 12500, NO count = 0) (12500 test cases)

Test #6:

score: 0
Accepted
time: 155ms
memory: 3896kb

input:

500
100
5 43 3 13 100 6 56 8 9 62 11 82 13 14 15 48 17 76 19 64 35 62 50 77 38 94 35 62 35 30 31 32 48 34 35 36 43 64 39 40 35 42 62 44 45 62 47 62 49 50 62 47 62 62 39 48 20 58 59 60 43 66 19 62 3 66 67 85 69 70 83 28 73 83 100 76 77 80 85 80 81 82 100 84 85 40 20 88 62 90 40 92 93 94 58 96 30 98 6...

output:

YES
4220
1 3
1 65
2 3 8
1 3
1 65
1 3
1 8
1 65
2 8 9
1 3
1 8
1 65
1 3
1 8
1 9
1 65
2 9 11
1 3
1 8
1 9
1 65
1 3
1 8
1 9
1 11
1 65
2 11 13
1 3
1 8
1 9
1 11
1 65
1 3
1 4
1 8
1 9
1 11
1 13
1 65
2 13 14
1 3
1 4
1 8
1 9
1 11
1 13
1 65
1 3
1 4
1 8
1 9
1 11
1 13
1 14
1 65
2 14 15
1 3
1 4
1 8
1 9
1 11
1 13
1 ...

result:

ok good! (YES count = 500, NO count = 0) (500 test cases)

Test #7:

score: 0
Accepted
time: 115ms
memory: 6908kb

input:

55
300
172 231 135 149 135 297 7 297 236 52 73 114 52 135 15 73 297 97 218 236 52 236 218 73 244 236 73 52 162 218 103 30 214 34 59 36 73 89 44 131 73 73 73 73 73 41 47 32 236 52 248 73 73 54 209 75 57 73 205 151 73 62 73 73 143 141 238 205 106 73 71 128 73 124 75 76 89 231 205 73 149 135 249 135 13...

output:

YES
12891
1 15
2 15 34
1 15
1 15
1 34
2 34 62
1 15
1 34
1 15
1 34
1 62
1 201
2 62 73
1 15
1 34
1 62
1 201
1 1
1 2
1 3
1 4
1 5
1 6
1 8
1 9
1 11
1 12
1 13
1 14
1 15
1 16
1 17
1 18
1 19
1 20
1 21
1 22
1 23
1 24
1 25
1 26
1 27
1 29
1 30
1 32
1 33
1 34
1 35
1 38
1 39
1 40
1 41
1 42
1 43
1 44
1 45
1 46
1 ...

result:

ok good! (YES count = 55, NO count = 0) (55 test cases)

Test #8:

score: 0
Accepted
time: 109ms
memory: 13996kb

input:

5
1000
794 193 3 4 888 279 316 8 621 679 376 254 791 550 362 706 677 133 133 279 279 57 557 471 780 471 110 557 264 317 557 927 264 908 589 193 481 38 39 941 619 473 683 340 817 780 876 548 557 193 589 648 264 471 940 528 557 710 57 57 61 142 133 481 679 142 712 264 557 264 683 468 679 204 398 754 3...

output:

YES
34853
1 38
2 38 158
1 38
1 38
1 158
2 158 253
1 38
1 158
1 38
1 158
1 253
2 253 266
1 38
1 158
1 253
1 38
1 158
1 253
1 266
2 266 331
1 38
1 158
1 253
1 266
1 38
1 158
1 253
1 266
1 331
2 331 352
1 38
1 158
1 253
1 266
1 331
1 38
1 158
1 253
1 266
1 331
1 352
2 352 356
1 38
1 158
1 253
1 266
1 3...

result:

ok good! (YES count = 5, NO count = 0) (5 test cases)

Test #9:

score: 0
Accepted
time: 22ms
memory: 11824kb

input:

5
1000
811 448 371 731 601 6 950 8 731 811 123 688 753 282 15 802 17 282 282 20 272 818 23 24 731 1 805 67 951 753 230 182 629 15 874 36 576 38 113 272 41 811 43 455 282 595 965 836 582 855 811 76 230 50 731 885 811 595 182 969 619 62 688 576 811 944 335 1 944 230 71 42 73 328 11 951 753 10 335 944 ...

output:

YES
59197
1 6
2 6 8
1 6
1 6
1 8
2 8 15
1 6
1 8
1 6
1 8
1 15
1 34
2 15 20
1 6
1 8
1 15
1 34
1 6
1 8
1 15
1 20
1 34
2 20 23
1 6
1 8
1 15
1 20
1 34
1 6
1 8
1 15
1 20
1 23
1 34
2 23 24
1 6
1 8
1 15
1 20
1 23
1 34
1 6
1 8
1 15
1 20
1 23
1 24
1 34
2 24 36
1 6
1 8
1 15
1 20
1 23
1 24
1 34
1 6
1 8
1 15
1 20...

result:

ok good! (YES count = 5, NO count = 0) (5 test cases)

Test #10:

score: 0
Accepted
time: 114ms
memory: 13628kb

input:

5
1000
1 696 3 4 70 98 715 8 174 10 11 12 342 530 15 878 928 191 447 20 21 878 23 436 367 4 174 28 321 666 31 911 33 34 35 526 66 38 39 868 41 440 43 710 45 988 47 48 62 50 383 612 300 569 878 56 84 58 560 60 61 401 63 64 815 647 67 68 69 70 670 72 73 74 75 846 77 784 554 80 208 82 142 84 85 590 87 ...

output:

YES
507484
1 1
2 1 3
1 1
1 1
1 3
2 3 4
1 1
1 3
1 1
1 3
1 4
1 26
1 229
2 4 8
1 1
1 3
1 4
1 26
1 229
1 1
1 3
1 4
1 8
1 26
1 229
2 8 10
1 1
1 3
1 4
1 8
1 26
1 229
1 1
1 3
1 4
1 8
1 10
1 26
1 229
2 10 11
1 1
1 3
1 4
1 8
1 10
1 26
1 229
1 1
1 3
1 4
1 8
1 10
1 11
1 26
1 229
2 11 12
1 1
1 3
1 4
1 8
1 10
1 ...

result:

ok good! (YES count = 5, NO count = 0) (5 test cases)

Test #11:

score: 0
Accepted
time: 155ms
memory: 17856kb

input:

5
1000
1 697 3 807 656 548 7 859 9 188 11 194 629 907 319 275 796 18 876 878 21 711 376 82 275 118 27 28 144 30 31 32 878 225 35 795 193 835 39 220 468 509 601 808 569 46 947 871 859 878 228 52 113 697 621 56 319 616 323 572 970 795 98 994 65 853 907 387 69 436 605 835 601 74 762 256 77 78 275 907 5...

output:

YES
307810
1 1
2 1 3
1 1
1 1
1 3
2 3 7
1 1
1 3
1 1
1 3
1 7
2 7 9
1 1
1 3
1 7
1 1
1 3
1 7
1 9
1 901
2 9 11
1 1
1 3
1 7
1 9
1 901
1 1
1 3
1 7
1 9
1 11
1 901
2 11 18
1 1
1 3
1 7
1 9
1 11
1 901
1 1
1 3
1 7
1 9
1 11
1 18
1 901
2 18 21
1 1
1 3
1 7
1 9
1 11
1 18
1 901
1 1
1 3
1 7
1 9
1 11
1 18
1 21
1 444
1...

result:

ok good! (YES count = 5, NO count = 0) (5 test cases)

Test #12:

score: 0
Accepted
time: 165ms
memory: 18112kb

input:

5
1000
1 2 500 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 689 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 452 86 684 88 89 90 91 550 93 94 95 96 97 98 74...

output:

YES
947417
1 1
2 1 2
1 1
1 1
1 2
2 2 4
1 1
1 2
1 1
1 2
1 4
2 4 5
1 1
1 2
1 4
1 1
1 2
1 4
1 5
2 5 6
1 1
1 2
1 4
1 5
1 1
1 2
1 4
1 5
1 6
2 6 7
1 1
1 2
1 4
1 5
1 6
1 1
1 2
1 4
1 5
1 6
1 7
2 7 8
1 1
1 2
1 4
1 5
1 6
1 7
1 1
1 2
1 4
1 5
1 6
1 7
1 8
2 8 9
1 1
1 2
1 4
1 5
1 6
1 7
1 8
1 1
1 2
1 4
1 5
1 6
1 7...

result:

ok good! (YES count = 5, NO count = 0) (5 test cases)

Test #13:

score: 0
Accepted
time: 176ms
memory: 17028kb

input:

5
1000
1 2 3 4 5 6 7 69 9 10 11 12 13 14 15 16 17 18 822 423 21 22 23 24 25 26 27 28 29 30 848 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 963 48 49 50 51 52 53 54 672 56 673 58 59 60 868 62 63 64 480 66 67 68 69 941 71 834 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 515 91 92 93 94 95 96 97...

output:

YES
900589
1 1
2 1 2
1 1
1 1
1 2
2 2 3
1 1
1 2
1 1
1 2
1 3
2 3 4
1 1
1 2
1 3
1 1
1 2
1 3
1 4
2 4 5
1 1
1 2
1 3
1 4
1 1
1 2
1 3
1 4
1 5
1 349
1 819
2 5 6
1 1
1 2
1 3
1 4
1 5
1 349
1 819
1 1
1 2
1 3
1 4
1 5
1 6
1 349
1 819
2 6 7
1 1
1 2
1 3
1 4
1 5
1 6
1 349
1 819
1 1
1 2
1 3
1 4
1 5
1 6
1 7
1 349
1 8...

result:

ok good! (YES count = 5, NO count = 0) (5 test cases)

Test #14:

score: 0
Accepted
time: 111ms
memory: 13692kb

input:

5
1000
433 256 696 228 253 435 436 725 47 766 308 958 433 851 399 433 258 328 748 435 468 725 982 24 748 157 748 999 958 725 27 553 435 819 139 553 748 304 39 676 289 228 33 725 748 851 811 735 435 47 819 399 531 435 738 191 433 304 559 60 748 800 227 47 982 658 47 586 69 748 991 191 325 107 183 644...

output:

YES
54480
1 39
2 39 69
1 39
1 39
1 69
2 69 92
1 39
1 69
1 39
1 69
1 92
1 124
2 92 98
1 39
1 69
1 92
1 124
1 39
1 69
1 92
1 98
1 124
2 98 100
1 39
1 69
1 92
1 98
1 124
1 39
1 69
1 92
1 98
1 100
1 124
2 100 163
1 39
1 69
1 92
1 98
1 100
1 124
1 39
1 69
1 92
1 98
1 100
1 124
1 163
2 163 164
1 39
1 69
1...

result:

ok good! (YES count = 5, NO count = 0) (5 test cases)

Test #15:

score: 0
Accepted
time: 282ms
memory: 18104kb

input:

5
1000
766 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 592 18 19 20 21 22 230 24 25 26 27 28 29 30 31 32 270 144 35 36 37 105 39 40 180 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 947 61 62 417 64 65 66 67 68 69 70 71 72 73 888 75 76 77 78 79 80 81 82 83 766 85 86 87 214 916 90 91 92 93 94 95 317...

output:

YES
845462
1 2
1 934
2 2 3
1 2
1 934
1 2
1 3
1 368
1 934
2 3 4
1 2
1 3
1 368
1 934
1 2
1 3
1 4
1 368
1 934
2 4 5
1 2
1 3
1 4
1 368
1 934
1 2
1 3
1 4
1 5
1 226
1 368
1 934
2 5 6
1 2
1 3
1 4
1 5
1 226
1 368
1 934
1 2
1 3
1 4
1 5
1 6
1 226
1 368
1 934
2 6 7
1 2
1 3
1 4
1 5
1 6
1 226
1 368
1 934
1 2
1 3...

result:

ok good! (YES count = 5, NO count = 0) (5 test cases)

Test #16:

score: 0
Accepted
time: 198ms
memory: 17192kb

input:

5
1000
392 897 227 735 327 707 615 226 153 102 593 398 726 696 857 894 17 823 799 322 109 714 931 260 762 823 988 827 799 949 694 916 867 123 398 747 633 367 931 916 231 89 891 44 45 538 938 175 49 376 799 762 960 696 327 327 997 477 726 799 857 714 339 398 916 231 799 68 69 894 71 696 73 255 50 395...

output:

YES
182704
1 17
2 17 44
1 17
1 17
1 44
2 44 45
1 17
1 44
1 17
1 44
1 45
2 45 49
1 17
1 44
1 45
1 17
1 44
1 45
1 49
2 49 68
1 17
1 44
1 45
1 49
1 17
1 44
1 45
1 49
1 68
2 68 69
1 17
1 44
1 45
1 49
1 68
1 17
1 44
1 45
1 49
1 68
1 69
2 69 71
1 17
1 44
1 45
1 49
1 68
1 69
1 17
1 44
1 45
1 49
1 68
1 69
1...

result:

ok good! (YES count = 5, NO count = 0) (5 test cases)

Test #17:

score: 0
Accepted
time: 84ms
memory: 10876kb

input:

5
1000
1 702 632 4 5 629 7 8 9 10 713 371 13 14 15 16 17 785 19 20 21 476 23 24 584 26 54 28 29 30 31 32 33 34 35 36 768 239 39 96 809 42 43 44 45 46 47 48 208 50 51 52 53 937 55 56 57 58 59 606 25 62 255 64 65 435 67 68 69 70 70 72 69 564 75 76 615 78 79 255 564 800 537 84 85 86 564 262 89 90 91 92...

output:

YES
450590
1 126
2 126 125
1 9
2 9 327
1 788
2 788 354
1 298
2 298 317
1 298
1 298
1 317
2 317 420
1 298
1 317
1 298
1 317
1 420
2 420 361
1 298
1 317
1 1
1 423
1 837
2 1 4
1 1
1 423
1 837
1 1
1 4
1 423
1 837
2 4 5
1 1
1 4
1 423
1 837
1 1
1 4
1 5
1 423
1 837
2 5 7
1 1
1 4
1 5
1 423
1 837
1 1
1 4
1 5...

result:

ok good! (YES count = 5, NO count = 0) (5 test cases)

Test #18:

score: 0
Accepted
time: 90ms
memory: 11368kb

input:

5
1000
167 610 3 858 1 592 201 496 9 10 11 969 13 14 290 705 618 18 19 62 21 22 23 25 25 562 509 28 29 162 31 32 1 502 518 1 906 501 39 40 41 42 43 44 779 17 979 530 49 737 51 52 53 54 55 56 57 779 533 60 61 822 54 64 65 66 509 68 69 562 71 72 73 587 509 76 77 78 848 80 81 723 83 84 142 936 562 868 ...

output:

YES
472425
1 9
1 157
2 9 10
1 9
1 157
1 9
1 10
1 157
1 328
1 466
1 500
1 569
1 823
1 967
2 10 11
1 9
1 10
1 157
1 328
1 466
1 500
1 569
1 823
1 967
1 9
1 10
1 11
1 157
1 328
1 466
1 500
1 569
1 823
1 967
2 11 13
1 9
1 10
1 11
1 157
1 328
1 466
1 500
1 569
1 823
1 967
1 9
1 10
1 11
1 13
1 157
1 328
1...

result:

ok good! (YES count = 5, NO count = 0) (5 test cases)

Test #19:

score: 0
Accepted
time: 216ms
memory: 15700kb

input:

5
1000
404 627 3 4 5 6 7 8 9 10 11 12 13 14 693 16 17 18 19 20 221 22 23 24 25 26 27 28 29 30 31 32 33 718 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 986 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 503 551 994 89 495 91 447 93 94 495 96 ...

output:

YES
575592
1 449
2 449 53
1 277
2 277 63
1 876
2 876 71
1 996
2 996 124
1 139
2 139 235
1 139
1 139
1 235
2 235 823
1 139
1 235
1 139
1 235
1 823
2 823 409
1 139
1 235
1 51
2 51 706
1 51
1 51
1 706
2 706 316
1 51
1 51
1 316
2 316 428
1 51
1 736
2 736 511
1 511
2 511 434
1 393
2 393 475
1 696
2 696 5...

result:

ok good! (YES count = 5, NO count = 0) (5 test cases)

Test #20:

score: 0
Accepted
time: 286ms
memory: 17868kb

input:

5
1000
1 2 3 4 5 6 7 8 9 511 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 575 27 28 29 30 31 32 33 34 35 36 37 822 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 804 62 63 64 65 66 67 477 69 70 71 72 73 74 75 76 77 78 79 80 691 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 941 9...

output:

YES
322830
1 102
2 102 339
1 102
1 102
1 339
2 339 848
1 102
1 339
1 102
1 339
1 848
2 848 31
1 102
1 339
1 274
2 274 37
1 224
2 224 345
1 224
1 224
1 345
2 345 836
1 224
1 836
2 836 49
1 273
2 273 86
1 977
2 977 526
1 526
2 526 101
1 403
2 403 956
1 403
1 403
1 956
2 956 465
1 403
1 956
1 465
1 956...

result:

ok good! (YES count = 5, NO count = 0) (5 test cases)

Test #21:

score: 0
Accepted
time: 212ms
memory: 3832kb

input:

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

output:

YES
2
1 10
2 10 7
YES
25
1 3
1 4
2 3 6
1 3
1 4
1 3
1 4
1 6
2 6 7
1 3
1 4
1 6
1 3
1 4
1 6
1 7
2 7 8
1 3
1 4
1 6
1 7
1 7
1 8
2 8 9
1 7
YES
15
1 1
2 1 6
1 1
1 1
1 6
2 6 9
1 1
1 6
1 6
1 9
2 9 5
1 6
1 2
1 4
2 4 7
YES
2
1 7
2 7 3
YES
7
1 2
2 2 5
1 2
1 2
1 5
2 5 4
1 2
YES
4
1 2
2 2 5
1 3
2 3 8
YES
42
1 1
2...

result:

ok good! (YES count = 50000, NO count = 0) (50000 test cases)

Test #22:

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

input:

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

output:

YES
2
1 7
2 7 3
YES
19
1 13
2 13 14
1 13
1 13
1 14
2 14 12
1 13
1 12
1 13
2 12 3
1 13
1 9
2 9 1
1 1
2 1 7
1 6
2 6 8
1 18
2 18 15
YES
23
1 9
2 9 4
1 7
2 7 10
1 7
1 3
1 7
1 8
1 10
2 10 17
1 3
1 7
1 10
1 3
1 7
1 10
1 17
2 17 6
1 3
1 7
1 10
1 2
2 2 14
YES
70
1 1
2 1 3
1 1
1 1
1 3
2 3 5
1 1
1 3
1 1
1 3
1...

result:

ok good! (YES count = 12500, NO count = 0) (12500 test cases)

Test #23:

score: 0
Accepted
time: 34ms
memory: 5840kb

input:

500
100
1 2 13 89 15 6 64 8 9 56 11 12 13 82 15 16 17 18 19 20 1 22 23 24 25 26 27 28 29 30 31 32 33 34 35 21 37 23 39 40 41 42 43 44 45 46 47 48 49 82 51 52 53 54 55 56 11 58 59 3 61 62 63 64 65 66 19 68 11 70 71 10 73 74 23 76 39 78 56 80 81 82 99 23 85 86 87 93 89 90 91 92 93 94 95 96 97 98 99 10...

output:

YES
261
1 42
2 42 46
1 42
1 42
1 46
2 46 78
1 42
1 78
2 78 8
1 95
2 95 17
1 1
2 1 30
1 1
1 1
1 30
2 30 32
1 1
1 30
1 1
1 30
1 32
2 32 87
1 1
1 30
1 87
2 87 19
1 58
2 58 20
1 56
2 56 90
1 56
1 56
1 90
2 90 27
1 56
1 16
2 16 55
1 16
1 16
1 55
2 55 28
1 16
1 24
2 24 59
1 24
1 24
1 59
2 59 82
1 24
1 24
...

result:

ok good! (YES count = 500, NO count = 0) (500 test cases)

Test #24:

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

input:

55
300
73 84 3 257 5 257 111 8 265 10 74 73 279 81 277 73 17 73 19 227 124 174 23 93 25 81 81 257 29 208 31 32 37 175 74 265 37 257 125 40 176 42 171 132 277 124 248 48 49 187 51 52 53 147 55 132 277 53 124 60 194 81 277 271 65 66 44 171 211 45 277 72 73 257 257 76 79 299 133 277 73 257 132 81 271 1...

output:

YES
9190
1 297
2 297 105
1 158
2 158 112
1 53
2 53 229
1 53
1 53
1 229
2 229 294
1 53
1 53
1 294
2 294 123
1 53
1 19
2 19 191
1 127
2 127 256
1 3
2 3 5
1 3
1 3
1 5
2 5 17
1 3
1 5
1 3
1 5
1 17
2 17 23
1 3
1 5
1 17
1 3
1 5
1 17
1 23
2 23 29
1 3
1 5
1 17
1 23
1 3
1 5
1 17
1 23
1 29
2 29 31
1 3
1 5
1 17...

result:

ok good! (YES count = 55, NO count = 0) (55 test cases)

Test #25:

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

input:

5
1000
1 2 3 4 705 6 7 8 9 10 11 781 13 231 15 16 17 18 19 20 21 22 23 24 25 26 27 401 29 42 31 445 667 289 35 36 37 761 996 40 41 42 43 251 45 46 47 231 49 50 51 52 53 54 55 56 57 35 59 60 61 62 63 64 65 66 538 401 69 70 71 72 73 74 75 554 77 78 79 344 81 82 83 84 85 442 51 88 89 90 91 92 93 94 891...

output:

YES
17
1 886
2 886 45
1 189
2 189 77
1 480
2 480 183
1 913
2 913 318
1 240
1 942
2 942 501
1 812
2 812 795
1 400
2 400 845
1 157
2 157 924
YES
93
1 498
2 498 26
1 259
2 259 28
1 580
2 580 59
1 220
2 220 72
1 22
2 22 76
1 911
2 911 86
1 407
2 407 104
1 504
2 504 123
1 117
2 117 129
1 993
2 993 145
1 ...

result:

ok good! (YES count = 5, NO count = 0) (5 test cases)

Test #26:

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

input:

5
1000
736 2 3 4 5 6 7 8 9 10 11 797 823 929 15 16 17 18 19 20 264 22 23 24 52 353 27 28 29 30 839 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 944 51 52 403 872 55 56 57 58 59 60 61 62 63 64 99 66 67 68 69 70 71 72 73 938 302 186 77 78 79 80 81 82 83 84 85 86 983 86 89 90 91 46 93 94 95 96...

output:

YES
222
1 949
2 949 22
1 176
2 176 52
1 317
2 317 70
1 789
2 789 73
1 651
2 651 79
1 408
2 408 80
1 23
2 23 577
1 23
1 23
1 577
2 577 97
1 23
1 250
2 250 124
1 665
2 665 156
1 177
1 289
2 289 158
1 144
2 144 179
1 860
2 860 183
1 618
2 618 205
1 358
2 358 215
1 549
1 993
2 549 924
1 924
2 924 263
1 ...

result:

ok good! (YES count = 5, NO count = 0) (5 test cases)

Test #27:

score: 0
Accepted
time: 22ms
memory: 6780kb

input:

5
1000
487 446 3 4 5 6 442 8 452 10 601 12 300 895 15 208 866 328 19 20 21 967 644 24 25 118 27 28 787 30 31 344 33 139 350 440 37 369 39 918 41 42 190 483 45 46 556 48 360 807 188 608 53 67 55 333 398 397 853 60 61 953 676 678 65 66 882 483 69 369 71 72 763 576 75 76 77 78 724 574 310 193 83 84 85 ...

output:

YES
484
1 291
2 291 10
1 651
2 651 20
1 321
1 967
2 967 45
1 274
2 274 66
1 416
2 416 69
1 76
2 76 285
1 76
1 76
1 285
2 285 86
1 76
1 248
2 248 119
1 357
2 357 134
1 202
2 202 135
1 46
2 46 500
1 500
2 500 154
1 344
1 998
2 344 178
1 53
2 53 391
1 53
1 53
1 391
2 391 77
1 53
1 77
1 266
1 938
2 77 1...

result:

ok good! (YES count = 5, NO count = 0) (5 test cases)

Test #28:

score: 0
Accepted
time: 7ms
memory: 6532kb

input:

5
1000
588 923 119 77 5 6 7 8 9 10 11 12 13 477 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 987 155 153 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 369 53 54 764 56 341 305 932 430 61 663 63 462 65 66 67 68 69 70 884 72 73 74 180 76 77 78 609 80 81 82 83 739 85 86 87 400 183 90 91 92 6...

output:

YES
105
1 354
2 354 9
1 667
2 667 410
1 410
2 410 20
1 374
2 374 25
1 535
2 535 53
1 159
2 159 91
1 26
2 26 105
1 910
2 910 128
1 879
2 879 149
1 521
2 521 176
1 966
2 966 179
1 349
2 349 262
1 97
2 97 266
1 968
2 968 289
1 743
2 743 312
1 540
2 540 153
1 153
2 153 341
1 679
2 679 856
1 571
1 856
2 ...

result:

ok good! (YES count = 5, NO count = 0) (5 test cases)

Test #29:

score: 0
Accepted
time: 6ms
memory: 6304kb

input:

5
1000
816 2 519 284 253 990 965 581 457 414 232 451 581 519 581 406 581 965 581 20 519 337 383 253 581 26 27 587 900 34 862 215 915 439 439 370 816 189 387 134 103 249 361 964 809 367 47 103 452 760 67 862 253 915 467 103 215 439 816 516 581 103 87 581 439 66 249 68 621 497 71 417 581 439 63 673 10...

output:

YES
1410
1 130
2 130 751
1 130
1 130
1 751
2 751 800
1 130
1 751
1 130
1 751
1 800
2 800 806
1 130
1 751
1 800
1 130
1 751
1 800
1 806
2 806 953
1 130
1 751
1 800
1 806
1 130
1 751
1 800
1 806
1 953
2 953 959
1 130
1 751
1 800
1 806
1 953
1 130
1 751
1 800
1 806
1 953
1 959
2 959 311
1 130
1 751
1 8...

result:

ok good! (YES count = 5, NO count = 0) (5 test cases)

Test #30:

score: 0
Accepted
time: 7ms
memory: 6856kb

input:

5
1000
816 2 235 51 617 979 7 981 979 113 604 984 51 773 790 33 750 466 14 803 556 190 349 51 733 816 190 207 828 816 885 76 47 880 850 349 767 773 120 141 500 979 27 44 883 190 816 630 869 984 773 141 154 900 773 349 349 500 786 118 750 154 516 349 30 154 883 113 733 979 197 451 816 816 816 51 815 ...

output:

YES
3666
1 514
2 514 467
1 44
2 44 100
1 44
1 44
1 100
2 100 162
1 44
1 100
1 44
1 100
1 162
2 162 178
1 44
1 100
1 162
1 44
1 100
1 162
1 178
2 178 213
1 44
1 100
1 162
1 178
1 44
1 100
1 162
1 178
1 213
2 213 231
1 44
1 100
1 162
1 178
1 213
1 44
1 100
1 162
1 178
1 213
1 231
2 231 261
1 44
1 100
...

result:

ok good! (YES count = 5, NO count = 0) (5 test cases)

Test #31:

score: 0
Accepted
time: 13ms
memory: 7092kb

input:

5
1000
1 2 3 22 949 6 7 8 9 10 11 12 547 33 1 16 17 520 19 20 21 22 23 928 111 26 631 994 29 236 657 32 33 34 35 898 37 38 765 685 41 42 43 44 45 46 961 48 49 556 51 619 53 785 55 56 57 180 59 60 61 62 166 64 65 66 67 95 69 70 71 72 73 74 75 866 77 78 79 80 328 82 257 243 85 86 87 88 89 90 91 92 93 ...

output:

YES
607
1 809
2 809 10
1 802
2 802 12
1 868
2 868 17
1 97
2 97 23
1 705
2 705 43
1 237
2 237 45
1 123
2 123 66
1 7
2 7 374
1 7
1 7
1 374
2 374 3
1 7
1 3
1 7
1 167
1 564
2 3 67
1 7
1 564
1 759
2 759 78
1 89
2 89 200
1 89
1 89
1 200
2 200 302
1 89
1 200
1 89
1 200
1 302
2 302 243
1 89
1 200
1 243
1 40...

result:

ok good! (YES count = 5, NO count = 0) (5 test cases)

Test #32:

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

input:

5
1000
1 2 924 4 5 6 7 8 9 10 867 919 13 8 15 850 17 18 922 20 884 543 23 824 25 47 990 28 29 30 791 32 33 34 35 208 37 38 39 491 41 870 43 274 45 46 47 410 49 50 871 52 53 54 55 540 57 58 59 60 61 62 63 94 65 66 67 68 924 70 71 72 73 74 75 76 407 78 79 980 81 82 83 84 85 86 87 514 89 90 91 92 619 9...

output:

YES
389
1 104
1 478
2 104 575
1 104
1 478
1 104
1 478
1 575
2 575 720
1 104
1 478
1 575
1 104
1 207
1 478
1 575
1 720
2 720 916
1 104
1 207
1 478
1 575
1 720
1 104
1 207
1 478
1 575
1 720
1 916
2 916 18
1 104
1 207
1 478
1 575
1 720
1 220
2 220 30
1 781
2 781 38
1 13
2 13 709
1 13
1 13
1 709
2 709 8...

result:

ok good! (YES count = 5, NO count = 0) (5 test cases)

Test #33:

score: -100
Time Limit Exceeded

input:

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

output:

NO

result: