题目链接:http://poj.org/problem?id=2912

题目:

题目大意:

n个人进行m轮剪刀石头布游戏(0<n<=500,0<=m<=2000)

接下来m行形如x,y,ch的输入,ch='='表示x,y平局, ch='>'表示x赢y,ch='<'表示x输y, 但是我们不知道x,y的手势是什么;

其中有一个人是裁判,它可以出任意手势,其余人手势相同的分一组,共分为三组,可以存 在空组。

也就是说除了裁判外,其余人每一次出的手 势都相同,问能不能确定裁判是几号,如果能,输出 最少在第几轮可以确定;

题解:

带权并查集

我们考虑枚举裁判,然后对每轮进行处理,包含当前枚举的裁判的轮我们直接跳过

二者之前的关系我们用0(=),1(>),2(<)表示,记得%3,用val数组记录当前点到所在并查集根节点的关系

对于每轮,我们首先判断是否在同一联通块里。如果在,判断当前关系是否符合,即val[b]是否等于val[a]+ch(我们定义ch是b连向a的),如果是就继续,不是的话说明当前的点不是裁判;如果不在,就带权合并一下就好了

那么最少的发现裁判的轮数呢?我们发现我们实际上在做一个排除法,那么我们最晚排除的那个人的轮数就是最少的发现裁判的轮数

#include<algorithm>
#include<cstring>
#include<cstdio>
#include<iostream>
using namespace std; const int N=+;
const int M=+;
int n,m;
int fa[N],a[M],b[M],ch[M],val[N];
int find(int x)
{
if (fa[x]==-) return x;
int tmp=find(fa[x]);
val[x]+=val[fa[x]];
val[x]%=;
return fa[x]=tmp;
}
int main()
{
while (~scanf("%d%d",&n,&m))
{
char c[];
for (int i=;i<=m;i++)
{
scanf("%s",c+);
a[i]=b[i]=;
int len=strlen(c+);
int l=;
while (c[l]>=''&&c[l]<='') a[i]=(a[i]<<)+(a[i]<<)+c[l]-'',l++;
if (c[l]=='=') ch[i]=;
if (c[l]=='>') ch[i]=;
if (c[l]=='<') ch[i]=;
l++;
while (c[l]>=''&&c[l]<=''&&l<=len) b[i]=(b[i]<<)+(b[i]<<)+c[l]-'',l++;
//printf("%d %d %d\n",a[i],ch[i],b[i]);
}
int round=,judger=-;
bool mark=false;
for (int i=;i<n;i++)
{
bool flag=false;
memset(fa,-,sizeof(fa));
memset(val,,sizeof(val));
for (int j=;j<=m;j++)
{
if (a[j]==i||b[j]==i) continue;
int fx=find(a[j]),fy=find(b[j]);
if (fx==fy)
{
if (val[b[j]]!=(val[a[j]]+ch[j]+)%)
{
round=max(round,j);
flag=true;
break;
}
}
else
{
fa[fy]=fx;
val[fy]=(val[a[j]]+ch[j]-val[b[j]]+)%;
}
}
if (!flag)//当前的是法官
{
if (judger==-)
{
judger=i;
}
else
{
mark=true;
break;
}
}
}
if (mark) printf("Can not determine\n");
else if (judger==-) printf("Impossible\n");
else printf("Player %d can be determined to be the judge after %d lines\n",judger,round);
}
return ;
}

[poj 2912] Rochambeau 解题报告 (带权并查集)的更多相关文章

  1. POJ 2912 - Rochambeau - [暴力枚举+带权并查集]

    题目链接:http://poj.org/problem?id=2912 Time Limit: 5000MS Memory Limit: 65536K Description N children a ...

  2. poj 2912 Rochambeau(枚举+带权并查集)

    题目链接:http://poj.org/problem?id=2912 题意:多个人玩石头剪刀布分成3组和一个裁判,每一组提前选定了自己出哪个手势,裁判可以随意出什么手势,问是否能够从给出的一系列石头 ...

  3. POJ 2912 Rochambeau(暴力)+【带权并查集】

    <题目链接> 题目大意: n个人进行m轮剪刀石头布游戏(0<n<=500,0<=m<=2000),接下来m行形如x, y, ch的输入,ch='='表示x, y平局 ...

  4. POJ 1988 Cube Stacking( 带权并查集 )*

    POJ 1988 Cube Stacking( 带权并查集 ) 非常棒的一道题!借鉴"找回失去的"博客 链接:传送门 题意: P次查询,每次查询有两种: M x y 将包含x的集合 ...

  5. poj 1733 Parity game(带权并查集+离散化)

    题目链接:http://poj.org/problem?id=1733 题目大意:有一个很长很长含有01的字符串,长度可达1000000000,首先告诉你字符串的长度n,再给一个m,表示给你m条信息, ...

  6. POJ 1988 Cube Stacking 【带权并查集】

    <题目链接> 题目大意: 有几个stack,初始里面有一个cube.支持两种操作: 1.move x y: 将x所在的stack移动到y所在stack的顶部. 2.count x:数在x所 ...

  7. POJ 1733 Parity game 【带权并查集】+【离散化】

    <题目链接> 题目大意: 一个由0,1组成的序列,每次给出一段区间的奇偶,问哪一条信息不合法. 解题分析: 我们用s[i]表示前i个数的前缀和,那么a b even意味着s[b]和s[a- ...

  8. POJ 1733 Parity game(离散化+带权并查集)

    离散化+带权并查集 题意:长度为n的0和1组成的字符串,然后问第L和R位置之间有奇数个1还是偶数个1. 根据这些回答, 判断第几个是错误(和之前有矛盾)的. 思路:此题同HDU 3038 差不多,询问 ...

  9. POJ:1182 食物链(带权并查集)

    http://poj.org/problem?id=1182 Description 动物王国中有三类动物A,B,C,这三类动物的食物链构成了有趣的环形.A吃B, B吃C,C吃A. 现有N个动物,以1 ...

随机推荐

  1. 优化报表系统结构之报表server计算

    在报表项目中,经常会碰到数据库压力非常大影响整个系统性能的问题.由以下的传统方案的结构示意图能够看出.所有数据存储和源数据计算都放在数据库完毕.当并发訪问量较大的时候,尽管每一个报表的数据量不大,还是 ...

  2. Brute force Attack

    1 Introduction A common threat that webdevelopers face is a password-guessing attack known as a brut ...

  3. Ext4,Ext3的特点和区别

    Linux kernel 自 2.6.28 开始正式支持新的文件系统 Ext4. Ext4 是 Ext3 的改进版,修改了 Ext3 中部分重要的数据结构,而不仅仅像 Ext3 对 Ext2 那样,只 ...

  4. sql server Delete误操作后如何恢复数据

    声明:本文是根据别人的经验https://blog.csdn.net/dba_huangzj/article/details/8491327写的总结 说明:update和delete时没有加where ...

  5. Windows 安装PostgreSQL

    下载二进制包:https://www.enterprisedb.com/download-postgresql-binaries 直接解压到C盘 Microsoft Windows [版本 6.3.9 ...

  6. Maven配置文件中配置指定JDK版本

    1. 在setting.xml文件中的<profiles>标签加入如下配置: <profile> <id>jdk-1.8</id> <activa ...

  7. c#0218-命名空间

    1 namespace 命名空间 可以解决类的重命名问题 可以看做是类的文件夹: 2 跨项目使用类 一个解决方案下有不同的项目,如果想在一个项目中引用另一个项目的类,解决方法是 1 添加引用 2 引用 ...

  8. 安卓怎么不如ios运行流畅

    一.优先级别不同:iOS最先响应屏幕当我们使用iOS或者是Android手机时,第一步就是滑屏解锁找到相应程序点击进入.而这个时候往往是所有操控开始的第一步骤,iOS系统产品就表现出来了流畅的一面,但 ...

  9. 响应式流API的构建基础

    下面三个重要的概念是响应式流API的构建基础: 发布者是事件的发送方,可以向它订阅. 订阅者是事件订阅方. 订阅将发布者和订阅者联系起来,使订阅者可以向发布者发送信号. http://www.info ...

  10. ActiveMQ学习笔记(8)----ActiveMQ的消息存储持久化

    1. 概述 ActiveMQ不仅支持persistent和non-persistent两种方式,还支持消息的恢复(recovery)方式. 2. PTP Queue的存储是很简单的,其实就是FIFO的 ...