标签:view 方案 com atom ace mon pac union panel
#include <iostream>
#include <cstring>
#include <cstdio>
using namespace std;
const int M = 1e5 + 10;
int a[M] , b[M];
int f[M] , va[M];
void init(int n) {
for(int i = 0 ; i <= n ; i++) {
f[i] = i;
va[i] = 1;
}
}
int find(int x) {
if(x != f[x])
f[x] = find(f[x]);
return f[x];
}
void Union(int x , int y) {
int xx = find(x);
int yy = find(y);
if(xx != yy) {
f[x] = yy;
va[yy] += va[xx];
}
}
int main()
{
int t;
scanf("%d" , &t);
while(t--) {
int n;
scanf("%d" , &n);
init(M);
for(int i = 0 ; i < n ; i++) {
scanf("%d" , &a[i]);
}
for(int i = 0 ; i < n ; i++) {
scanf("%d" , &b[i]);
Union(a[i] , b[i]);
}
int count = 0;
for(int i = 0 ; i < n ; i++) {
if(f[a[i]] == a[i]) {
if(va[a[i]] == 1) {
count++;
}
else {
count += (va[a[i]] - 1);
}
}
}
printf("%d\n" , count);
}
return 0;
}
标签:view 方案 com atom ace mon pac union panel
原文地址:http://www.cnblogs.com/TnT2333333/p/6053923.html