卿学姐与诡异村庄

Time Limit: 4500/1500MS (Java/Others)     Memory Limit: 65535/65535KB (Java/Others)
Submit Status

日复一日,年复一年,春去秋来。

卿学姐终于从天行廖那里毕业啦。出山的卿学姐首先来到了一个诡异的村庄。

在这个村庄中,只有两种人,一种是好人,一种是坏人。

好人只说真话,坏人只说假话。

村庄虚伪的平静由于卿学姐的到来,终于被打破了。

人们开始互相指控,每个人都会说另外一个人是否是好人。

卿学姐修行途中只学会了膜法,却不谙世事,所以卿学姐无法确认哪些人是好人,哪些人是坏人。

但是机智的卿学姐意识到可以通过这些人的指控来分辨。

现在告诉你村庄中每个人指控谁是否为好人,请问是否有个合理的分类能够符合所有的指控。

Input

第一行一个整数NN,表示村庄总共有NN个人,村民从11开始编号到NN

1≤N≤1000001≤N≤100000

接下来NN行,每行两个整数,ai,tai,t,如果tt是11,那么说明第ii个人认为第aiai个人是好人。如果tt是22,那么说明第ii个人认为第aiai个人是坏人。

1≤ai≤N

Output

如果存在一个好人坏人的分类能够满足所有的指控,那么输出"Time to show my power",否则输出"One face meng bi"

Sample input and output

Sample Input Sample Output
3
2 2
3 1
1 2
Time to show my power
3
2 2
3 2
1 2
One face meng bi

Hint

第一组样例中,如果1是好人,2和3都是坏人,就能解释得通这些指控

Source

2016 UESTC Training for Data Structures

代码

 #include<iostream>
#include<cstring>
#include<cstdio>
#include<algorithm>
#include<vector>
#include<queue>
const int MAXN=;
using namespace std; int vis[MAXN],N,next_[MAXN],think_huai[MAXN],col[MAXN];
vector<int> vec;
//1(2-1)是坏人,0是好人
int dfs(int x){
vis[x]=;
if( next_[x] && !vis[next_[x] ] ) dfs( next_[x] );
vec.push_back(x);
} int paint(int x,int c){
vis[x]=;//不管怎样都已经访问 ,但col不一样
col[x]=c; //之后染色成功才会进行染色 if(next_[x]){
if(c){//如果x是坏人,染反色
if(col[next_[x]]>=){//如果儿纸已经染色
if( (think_huai[x]^) != col[next_[x]] ) {col[x]=-;return ;}//儿纸不成功就不染
}
else if(!paint(next_[x],think_huai[x]^)) {col[x]=-;return ;}
}
else{
if(col[next_[x]]>=){
if( (think_huai[x]) != col[next_[x]] ) {col[x]=-;return ;}
}
else if(!paint(next_[x],think_huai[x])) {col[x]=-;return ;}
}
} return ;
} int scc(){
memset(vis,,sizeof(vis));
for(int i=;i<=N;i++)
if(!vis[i]) dfs(i); memset(vis,,sizeof(vis));
for(int i=N-;i>=;i--){
int now=vec[i];
if(!vis[now]){
if(!paint(now,)){
if(!paint(now,)){
puts("One face meng bi");
exit();
}
}
}
}
// paint(1,1);
return ;
} int main(){
// freopen("01.in","r",stdin);
scanf("%d",&N);
for(int i=;i<=N;i++){
int flag=,tmp=;
scanf("%d%d",&tmp,&flag);
next_[i]=tmp;think_huai[i]=flag-;
} memset(col,-,sizeof(col));
if(scc()) puts("Time to show my power");
return ;
}

长长的可能会TLE的二分图

据说并查集是正解,类似食物链,待写~

 #include<iostream>
#include<cstring>
#include<cstdio>
#include<algorithm>
#include<vector>
#include<queue>
const int MAXN=;
using namespace std; int N;
int think_list[MAXN],think_label[MAXN],vis[MAXN];
int fa[*MAXN],d[MAXN];
//fa 前一半是好人 后一半是坏人 int Find(int a){
if(a==fa[a]) return a;
else return fa[a]=Find(fa[a]);
} void unite(int a,int b){
int ta=Find(a),tb=Find(b);
if(ta!=tb) fa[ta]=tb;
} int check(int x,int c){
d[x]=c;
vis[x]=;
if(think_list[x]){
int to=think_list[x],flag=think_label[x];
if(!c){//如果c是好人
if(vis[to]){
if(Find(x)==Find(to+MAXN)&&flag==d[to]^) {vis[x]=;return ;}
if(Find(x)==Find(to)&&flag==d[to]^) {vis[x]=;return ;}
}
if(!vis[to]&&!check(to,flag)) {vis[x]=;return ;}
}
else{
if(vis[to]){
if(Find(x)==Find(to+MAXN)&&flag==d[to]) {vis[x]=;return ;}
if(Find(x)==Find(to)&&flag==d[to]) {vis[x]=;return ;}
}
if(!vis[to]&&!check(to,flag^)) {vis[x]=;return ;}
}
}
return ;
} int main(){
// freopen("01.in","r",stdin);
memset(d,-,sizeof(d)); scanf("%d",&N);
for(int i=;i<*MAXN;i++) fa[i]=i; for(int i=;i<=N;i++){
int flag,x;
scanf("%d%d",&x,&flag);flag-=;
think_list[i]=x;
think_label[i]=flag;//1是坏人 0是好人 if(flag==){
unite(i,x);
// unite(i+MAXN,x);
}
else{//坏人
unite(i,x+MAXN);
// unite(i+MAXN,x+MAXN);
}
}
for(int i=;i<=N;i++){
if(!vis[i]){
if(!check(i,)){
if(!check(i,)){
puts("One face meng bi");
exit();
}
}
}
}
puts("Time to show my power");
return ;
}

长长的速度没差多少的并查集

cdoj 1328 卿学姐与诡异村庄 Label:并查集 || 二分图染色的更多相关文章

  1. cdoj1328卿学姐与诡异村庄

    地址:http://acm.uestc.edu.cn/#/problem/show/1328 题目: 卿学姐与诡异村庄 Time Limit: 4500/1500MS (Java/Others)    ...

  2. C - 卿学姐与诡异村庄(并查集+One face meng bi)

    卿学姐与诡异村庄 Time Limit: 4500/1500MS (Java/Others)     Memory Limit: 65535/65535KB (Java/Others) Submit  ...

  3. CDOJ 1324 卿学姐与公主(分块)

    CDOJ 1324 卿学姐与公主(分块) 传送门: UESTC Online Judgehttp://acm.uestc.edu.cn/#/problem/show/1324 某日,百无聊赖的卿学姐打 ...

  4. cdoj 1329 卿学姐与魔法 优先队列

    卿学姐与魔法 Time Limit: 1200/800MS (Java/Others)     Memory Limit: 65535/65535KB (Java/Others) Submit Sta ...

  5. cdoj 1324 卿学姐与公主 线段树裸题

    卿学姐与公主 Time Limit: 2000/1000MS (Java/Others)     Memory Limit: 65535/65535KB (Java/Others) Submit St ...

  6. CDOJ 1292 卿学姐种花 暴力 分块 线段树

    卿学姐种花 题目连接: http://acm.uestc.edu.cn/#/problem/show/1292 Description 众所周知,在喵哈哈村,有一个温柔善良的卿学姐. 卿学姐喜欢和她一 ...

  7. CDOJ 1324 卿学姐与公主 分块

    题目地址 分块模板 #include<cstdio> #include<algorithm> #include<math.h> using namespace st ...

  8. cdoj1344卿学姐种美丽的花

    地址:http://acm.uestc.edu.cn/#/problem/show/1344 题目: 卿学姐种美丽的花 Time Limit: 8000/4000MS (Java/Others)    ...

  9. CDOJ 1281 暴兵的卿学姐 构造题

    暴兵的卿学姐 题目连接: http://acm.uestc.edu.cn/#/problem/show/1281 Description 沈宝宝又和卿学姐开始玩SC2了! 自从沈宝宝学会新的阵型后,就 ...

随机推荐

  1. 【SQL】检索满足条件的最大值的数据集合

    是不是看题目觉的看不懂?其实我自己也看不懂,但是又找不到更好的词来形容. 为了更好的表达我的意思,请看下. 如果有一张成绩表(Points), 学生(student) 成绩(point) 科目(sub ...

  2. Delphi编程建议遵守的规范1---缩进、各种语句的用法

    在编程时候,尤其是在一个大的团队里面,遵守统一的编程规范是极其重要的.为所有的开发人员制定一个源代码书写标准,以及程序和文件的命名标准,使他们在编程时有一致的格式,这样,每个编程人员编写的代码能够被其 ...

  3. MVC基础知识

    1.View中获取Control和View: //获取控制器名称: ViewContext.RouteData.Values["controller"].ToString(); / ...

  4. 中断处理流程,ok6410

    中断处理流程 CPU在工作的过程中,经常需要与外设进行交互,交互的方式包括”轮询方式”,”中断方式”. 1.轮询方式: CPU不断地查询设备的状态.该方式实现比较简单,但CPU利用率很低,不适合多任务 ...

  5. 管道通信,王明学learn

    管道通信 一.通讯目的 1.数据传输 一个进程需要将数据发送给另一个进程. 2.资源共享 多个进程之间共享同样的资源. 3.通知事件 一个进程需要向另一个/组进程发送消息,通知它们发生了某事件. 4. ...

  6. 用计算器计算“异或CRC”

    再计算器上输入以下数字,每输入一个数字,按一下“Xor”

  7. Eclipse的详细安装步骤

    第一种:这个方法是在线安装的  第二种:下载完整免安装包 首先打开网址:http://www.eclipse.org/ 然后在这里我就选择64位的安装,就以安装安卓开发的举例: 然后下载即可:

  8. 智能车学习(六)——OLED屏幕使用

    一.代码展示 1.头文件: #ifndef OLED_H_ #define OLED_H_ extern unsigned char Draw[]; extern const unsigned cha ...

  9. 关于MFC OpenGL环境配置的一点总结

    复制include时要小心..看vs给你load哪一个..名字一样..东西可不一定一样哦 http://www.cppblog.com/wicbnu/archive/2010/09/30/128123 ...

  10. 【MySQL 安装过程1】顺利安装MySQL完整过程

    一.MySQL Sever的安装 1.开始安装: 2.这里就要开始注意,端口号我们的my SQL端口号为3306 3.下面要输入用户名和用户密码.注意,帐号密码  都是 root. 4.下面的最后一页 ...