记录编号 |
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;
- }