BZOJ 1923: [Sdoi2010]外星千足虫 高斯消元+bitset

时间:2022-01-12 07:04:02

高斯消元求解异或方程组,可以多学一下 $bitset$ 在位运算中的各种神奇操作.

#include <cstdio>
#include <bitset>
#define N 2004
#define setIO(s) freopen(s".in","r",stdin) , freopen(s".out","w",stdout)
using namespace std;
int n,m,ans;
char str[N];
bitset<N>v[N];
int main()
{
int i,j,k;
// setIO("input");
scanf("%d%d",&n,&m);
for(i=1;i<=m;++i)
{
int tmp;
scanf("%s%d",str+1,&tmp);
for(j=1;j<=n;++j) v[i][j]=(str[j]=='0'?0:1);
v[i][n+1]=tmp;
}
for(i=1;i<=n;++i)
{
for(j=i;j<=m;++j)
{
if(v[j][i])
{
ans=max(ans,j),swap(v[j],v[i]);
break;
}
}
if(!v[i][i])
{
printf("Cannot Determine\n");
return 0;
}
for(j=i+1;j<=m;++j) if(v[j][i]) v[j]^=v[i];
}
printf("%d\n",ans);
for(i=1;i<=n;++i)
{
for(j=i+1;j<=n;++j) if(v[i][j]) v[i]^=v[j];
if(v[i][n+1]) printf("?y7M#\n");
else printf("Earth\n");
}
return 0;
}