N个小朋友(编号为0,1,2,…,N-1)一起玩石头剪子布游戏。

其中一人为裁判,其余的人被分为三个组(有可能有一些组是空的),第一个组的小朋友只能出石头,第二个组的小朋友只能出剪子,第三个组的小朋友只能出布,而裁判可以使用任意手势。

你不知道谁是裁判,也不知道小朋友们是怎么分组的。

然后,孩子们开始玩游戏,游戏一共进行M轮,每轮从N个小朋友中选出两个小朋友进行猜拳。

你将被告知两个小朋友猜拳的胜负结果,但是你不会被告知两个小朋友具体使用了哪种手势。

比赛结束后,你能根据这些结果推断出裁判是谁吗?

如果可以的话,你最早在第几轮可以找到裁判。

输入格式
输入可能包含多组测试用例

每组测试用例第一行包含两个整数N和M。

接下来M行,每行包含两个整数a,b,中间夹着一个符号(‘>’,’=’,’<’),表示一轮猜拳的结果。

两个整数为小朋友的编号,”a>b”表示a赢了b,”a=b”表示a和b平手,”a<b”表示a输给了b。

输出格式
每组测试用例输出一行结果,如果找到裁判,且只能有一个人是裁判,则输出裁判编号和确定轮数。

如果找到裁判,但裁判的人选多于1个,则输出“Can not determine”。

如果根据输入推断的结果是必须没有裁判或者必须有多个裁判,则输出“Impossible”。

具体格式可参考样例。

数据范围
1≤N≤500,
0≤M≤2000
输入样例:
3 3
0<1
1<2
2<0
3 5
0<1
0>1
1<2
1>2
0<2
4 4
0<1
0>1
2<3
2>3
1 0
输出样例:
Can not determine
Player 1 can be determined to be the judge after 4 lines
Impossible
Player 0 can be determined to be the judge after 0 lines

思路:
每个点拆成三份
x x x:同类域
x + n x+n x+n:能打败的域
x + 2 ∗ n x+2*n x+2∗n:被打败的域

按照这个思路来处理点之间的关系。
我们枚举裁判点,然后出现裁判的不等式就去掉,如果中间没有矛盾就说明这是一个合法裁判。统计合法裁判的数量和出现的位置。

#include <cstdio>
#include <cstring>
#include <algorithm>
#include <vector>
#include <map>
using namespace std;
typedef long long ll;
const int INF = 0x3f3f3f3f;
const int maxn = 2005;
struct Expr{int x,y;char op;
}expr[maxn];
int n,m;
int fa[maxn],ind[maxn];
int findset(int x) {if(fa[x] == x) return x;return fa[x] = findset(fa[x]);
}
void Union(int x,int y) {int rx = findset(x),ry = findset(y);if(rx != ry) {fa[rx] = ry;}
}
//x:同类,x+n:能打败,x+2*n:被打败
bool conflict(Expr&now) { //是否发生冲突int x = now.x,y = now.y;if(now.op == '=') {if(findset(x) == findset(y + n) || findset(x + n) == findset(y)) return true;Union(x,y);Union(x + n,y + n);Union(x + 2 * n,y + 2 * n);} else if(now.op == '>') {if(findset(x) == findset(y) || findset(x) == findset(y + n)) return true;Union(x,y + 2 * n);Union(x + n,y);Union(x + 2 * n,y + n);} else if(now.op == '<') {if(findset(x) == findset(y) || findset(x) == findset(y + 2 * n)) return true;Union(x,y + n);Union(x + n,y + 2 * n);Union(x + 2 * n,y);}return false;
}int main() {while(~scanf("%d%d",&n,&m)) {for(int i = 0;i < m;i++) {scanf("%d%c%d",&expr[i].x,&expr[i].op,&expr[i].y);}for(int i = 0;i < n;i++) ind[i] = 0;int cnt = 0;//裁判个数int id = 0;//裁判位置for(int i = 0;i < n;i++) { //枚举裁判for(int j = 0;j < n * 3;j++) fa[j] = j;int flag = 1;for(int j = 0;j < m;j++) {if(expr[j].x == i || expr[j].y == i) continue;if(conflict(expr[j])) {ind[i] = j + 1;flag = 0;break;}}if(flag) {cnt++;id = i;}}
//        printf("DEBUG %d\n",cnt);if(cnt == 0) {printf("Impossible\n");} else if(cnt == 1) {int pos = 0;for(int i = 0;i < n;i++) pos = max(pos,ind[i]);printf("Player %d can be determined to be the judge after %d lines\n",id,pos);} else {printf("Can not determine\n");}}return 0;
}

AcWing 258. 石头剪子布(扩展域并查集)相关推荐

  1. 1132:石头剪子布

    时间限制: 1000 ms 内存限制: 65536 KB 提交数: 9833 通过数: 5176 [题目描述] 石头剪子布,是一种猜拳游戏.起源于中国,然后传到日本.朝鲜等地,随着亚欧贸易的不断发展它 ...

  2. 1.7编程基础之字符串_04石头剪子布

    http://noi.openjudge.cn/ch0107/04/ /* 1.7编程基础之字符串_04石头剪子布 http://noi.openjudge.cn/ch0107/04/ */ #inc ...

  3. 信息学奥赛一本通 1132:石头剪子布 | OpenJudge NOI 1.7 04

    [题目链接] ybt 1132:石头剪子布 OpenJudge NOI 1.7 04:石头剪子布 [题目考点] 1. 字符串处理 2. 判断字符串相同 s1,s2是字符数组,判断二者是否相同:strc ...

  4. 信息学奥赛一本通(1132:石头剪子布)

    1132:石头剪子布 时间限制: 1000 ms         内存限制: 65536 KB 提交数: 29385     通过数: 15475 [题目描述] 石头剪子布,是一种猜拳游戏.起源于中国 ...

  5. 石头剪子布(信息学奥赛一本通-T1132)

    [题目描述] 石头剪子布,是一种猜拳游戏.起源于中国,然后传到日本.朝鲜等地,随着亚欧贸易的不断发展它传到了欧洲,到了近现代逐渐风靡世界.简单明了的规则,使得石头剪子布没有任何规则漏洞可钻,单次玩法比 ...

  6. 信息学奥赛C++语言:石头剪子布

    [题目描述] 石头剪子布,是一种猜拳游戏.起源于中国,然后传到日本.朝鲜等地,随着亚欧贸易的不断发展它传到了欧洲,到了近现代逐渐风靡世界.简单明了的规则,使得石头剪子布没有任何规则漏洞可钻,单次玩法比 ...

  7. 石头剪子布蜥蜴史波克python_C++字符串——石头剪刀布

    石头剪子布,是一种猜拳游戏.起源于中国,然后传到日本.朝鲜等地,随着亚欧贸易的不断发展它传到了欧洲,到了近现代逐渐风靡世界.简单明了的规则,使得石头剪子布没有任何规则漏洞可钻,单次玩法比拼运气,多回合 ...

  8. 石头剪刀布python代码_Python实现的石头剪子布代码分享

    我之前写过一篇基于JS的石头剪子布程序 <JavaScript实现的石头剪刀布游戏源码分享>,今天又基于Python写了一个实例,这里边的算法有点特殊但一时也想不到一个好的算法规律. 代码 ...

  9. c语言射击类小游戏任务书,(c语言课程设计报告小游戏“石头剪子布”.doc

    (c语言课程设计报告小游戏"石头剪子布" <C语言课程设计>报告 题目:石头剪子布 班级: 学号: 姓名: 指导教师: 成绩: 目 录: 一.选题背景- 3 - 二.设 ...

最新文章

  1. numpy找到数组中符合条件的数
  2. 安卓机更新系统会卡吗_iOS13.3系统值得更新吗?信号怎么样?续航改善了没有?...
  3. MINIGUI图形界面开发入门,交叉编译,移植
  4. Backend Qt5Agg is interactive backend. Turning interactive mode on.
  5. weblogic发序列化命令执行漏洞工具分享
  6. 资源 | 没有数学和编程基础,这几个数据科学项目了解一下
  7. 页面布局_【三十七集】页面布局中的视觉流
  8. python字符串_Python的字符串和编码
  9. html分享到微博,前端实现分享内容到微博、QQ、QQ空间、豆瓣等平台
  10. 收银机多少钱一台推荐科脉系统_收银系统多少钱一套?常用收银系统价格大盘点...
  11. App消息推送策略:推送用户感兴趣的内容
  12. 小程序 40163_小程序获取openid 出现null,{errcode:40163,errmsg:code been used, hints: [ req_id: WNUzlA0105t...
  13. 程序员业余时间修炼指南
  14. mysql general bin区别_MySQL_Mysql常见问题集锦,1,utf8_bin跟utf8_general_ci的区别 - phpStudy...
  15. firebox 浏览器查看cookie的方法
  16. 用AkShare获取实盘沪深可转债数据
  17. H5 语音合成播报功能
  18. 蓝桥杯2022年第十三届省赛真题-纸张尺寸
  19. Linux网络基础之DNS服务
  20. Excel自动生成sql建表语句

热门文章

  1. 二、【python计算机视觉编程】局部图像描述子
  2. Android蓝牙增加自定义按键
  3. (Hadoop3)HDFS文件系统
  4. NLP --- 对抗学习:从FGM, PGD到FreeLB
  5. “互联网+大数据”成为审讯突破口
  6. Typora免费版下载安装
  7. SRS解决RTMP转RTC的爆音问题
  8. tp5 File文件写入(生成静态文件)
  9. 设置Activity使用系统壁纸作为背景
  10. flex布局换行后均匀分布