题解 P4575 【[CQOI2013]图的逆变换】
大致思路就是:如果在图 D 中:
也就是说,两个点指向一个公共的点,那么它们所有出边指向的点集必然相同,事实上这是存在 D 的充要条件,证明不难。
之前几篇题解要么用了并查集,要么用了数组暴力判断,这里提供一种不难想且速度不慢的方法:Bitset。
用 Bitset 记录邻接矩阵,枚举两行,算一下两行的与和异或,如果与不为
#include <bits/stdc++.h>
using namespace std;
const int MAXN=310;
int t,n,m,x,y;
bitset <MAXN> b[MAXN],tmp1,tmp2;
int main () {
scanf("%d",&t);
for (int ii=1;ii<=t;ii++) {
scanf("%d%d",&n,&m);
for (int i=1;i<=n;i++) {b[i].reset();}
for (int i=1;i<=m;i++) {
scanf("%d%d",&x,&y);
x++,y++;
b[x].set(y);
}
int flg=0;
for (int i=1;i<=n;i++) {
if (flg) {break;}
for (int j=1;j<=n;j++) {
tmp1=b[i]&b[j],tmp2=b[i]^b[j];
if (tmp1.count()!=0&&tmp2.count()!=0) {flg=1;break;}
}
}
printf("%s\n",flg?"No":"Yes");
}
return 0;
}