记录编号 |
123968 |
评测结果 |
AAAAAAAAAA |
题目名称 |
[CEOI 1999] 奇偶性游戏 |
最终得分 |
100 |
用户昵称 |
cstdio |
是否通过 |
通过 |
代码语言 |
C++ |
运行时间 |
0.013 s |
提交时间 |
2014-10-01 21:05:57 |
内存使用 |
0.46 MiB |
显示代码纯文本
#include<iostream>
#include<cstdio>
#include<algorithm>
#include<cstring>
#include<vector>
#include<map>
using namespace std;
const int SIZEN=10010;
int L,N;
class REQ{
public:
int a,b,w;//[a,b],答案w
}R[SIZEN];
int ufs[SIZEN]={0},flen[SIZEN]={0};
vector<int> X;
map<int,int> MP;
int grand(int x,int &k){
if(ufs[x]==-1){k=0;return x;}
ufs[x]=grand(ufs[x],k);
k=(flen[x]^=k);
return ufs[x];
}
void work(void){
int ga,gb,ka,kb;
for(int i=1;i<=N;i++){
ga=grand(R[i].a,ka);
gb=grand(R[i].b,kb);
if(ga!=gb){
ufs[ga]=gb;
flen[ga]=R[i].w^ka^kb;
}
else{
if(ka^kb!=R[i].w){
printf("%d\n",i-1);
return;
}
}
}
printf("%d\n",N);
}
void read(void){
scanf("%d%d",&L,&N);
char ch[10];
for(int i=1;i<=N;i++){
scanf("%d%d",&R[i].a,&R[i].b);
scanf("%s",ch);
if(ch[0]=='e') R[i].w=0;
else R[i].w=1;
X.push_back(R[i].a-1);
X.push_back(R[i].b);
}
sort(X.begin(),X.end());
int tot=0;
for(int i=0;i<X.size();i++)
if(!i||X[i]!=X[i-1]) MP[X[i]]=++tot;
for(int i=1;i<=N;i++){
R[i].a=MP[R[i].a-1];
R[i].b=MP[R[i].b];
}
}
int main(){
freopen("parity.in","r",stdin);
freopen("parity.out","w",stdout);
memset(ufs,-1,sizeof(ufs));
read();
work();
return 0;
}