标签:tchar not ann stdin target 方便 sdoi stream online
高斯消元求解Xor方程。
这个方程很容易换成xor的方程。然后用高斯消元搞就行了。
用bitset实现这个非常方便。
//BZOJ 1923
//by Cydiater
//2016.11.3
#include <iostream>
#include <queue>
#include <map>
#include <ctime>
#include <cmath>
#include <cstring>
#include <string>
#include <algorithm>
#include <cstdio>
#include <cstdlib>
#include <iomanip>
#include <set>
#include <bitset>
using namespace std;
#define up(i,j,n) for(int i=j;i<=n;i++)
#define down(i,j,n) for(int i=j;i>=n;i--)
#define cmax(a,b) a=max(a,b)
#define cmin(a,b) a=min(a,b)
#define ll long long
#define bs bitset<1005>
const int MAXN=2e3+5;
const int oo=0x3f3f3f3f;
inline int read(){
char ch=getchar();int x=0,f=1;
while(ch>‘9‘||ch<‘0‘){if(ch==‘-‘)f=-1;ch=getchar();}
while(ch>=‘0‘&&ch<=‘9‘){x=x*10+ch-‘0‘;ch=getchar();}
return x*f;
}
int N,MM,ans=0;
bs M[MAXN];
char s[MAXN];
namespace solution{
void init(){
N=read();MM=read();
up(i,1,MM){
scanf("%s",s+1);
up(j,1,N)M[i][j]=s[j]-‘0‘;
scanf("%s",s+1);
M[i][N+1]=s[1]-‘0‘;
}
}
void Guass(){
up(i,1,N){
up(j,i,MM)if(M[j][i]){cmax(ans,j);if(i!=j)swap(M[i],M[j]);break;}
if(!M[i][i]){ans=-1;break;}
up(j,1,MM)if(M[j][i]&&j!=i)M[j]^=M[i];
}
}
void slove(){
Guass();
if(ans==-1)puts("Cannot Determine");
else{
cout<<ans<<endl;
up(i,1,N)if(M[i][N+1])puts("?y7M#");
else puts("Earth");
}
}
}
int main(){
//freopen("input.in","r",stdin);
using namespace solution;
init();
slove();
return 0;
}
标签:tchar not ann stdin target 方便 sdoi stream online
原文地址:http://www.cnblogs.com/Cydiater/p/6026151.html