一群小孩玩一个简单石头布布游戏,这些小孩会分成三组(组内可能没有人)+一个自由人(比翻译成裁判合理多了),同一组的小孩只会出同一种手势(不会变的),不过裁判可以出任意的手势,这些小孩能就会相互猜拳玩,A>B代表A赢B, <代表输, =代表平了,给你这些小孩玩游戏的结果,问你能不能找到那个自由人,如果找不出来,就输出Can not determine,如果发现不可能有这样的结果,除非有不止一个自由者那就输出Impossible,如果就一个自由者,那就输出这个自由者,和最先能判断这个自由者的位置的行号。。。

///////////////////////////////////
跟食物链差不多,查找自由者可以枚举每个人,比较简单就不说了
#include<iostream>
#include<algorithm>
#include<stdio.h>
#include<math.h>
#include<string.h>
#include<queue>
#include<stack>
using namespace std; const int maxn = ; int f[maxn], val[maxn];
//0代表同类, 1代表赢, 2代表输
struct node{int u, v, rel;}data[maxn*]; int Find(int x)
{
    int k = f[x];
    if(f[x] != x)
    {
        f[x] = Find(f[x]);
        val[x] = (val[x]+val[k])%;
    }     return f[x];
}
//如果k是裁判是否有矛盾产生,有返回产生矛盾的行数, 没有返回-1
int Solve(int k, int N, int M)
{//这里跟食物链一样的
    int i, u, v, ru, rv;     for(i=; i<N; i++)
        f[i] = i, val[i]=;
    for(i=; i<M; i++)
    {
        u = data[i].u, v = data[i].v;
        if(u != k && v != k)
        {
            ru = Find(u), rv = Find(v);             if(ru == rv && (val[v]+data[i].rel)% != val[u] )
                return i;
            f[ru] = rv;
            val[ru] = (data[i].rel-val[u]+val[v]+)%;
        }
    }     return -;
} int main()
{
    int i, N, M;     while(scanf("%d%d", &N, &M) != EOF)
    {
        char ch;         for(i=; i<M; i++)
        {
            scanf("%d%c%d", &data[i].u, &ch, &data[i].v);
            if(ch == '=')
                data[i].rel = ;
            else if(ch == '>')
                data[i].rel = ;
            else
                data[i].rel = ;
        }         int p = Solve(-, N, M);
        
        //没有矛盾产生,无法判断出谁是裁判
        if(N !=  && p == -)
            printf("Can not determine\n");
        else if(N == )//只有一个人,只能是裁判
            printf("Player 0 can be determined to be the judge after 0 lines\n");
        else
        {
            int k=, q, j;//k记录有多少个可以担任裁判             for(i=; i<N; i++)
            {
                j = Solve(i, N, M);
                if(j == -)
                    k++, q = i;
                else
                    p = max(p, j);//因为要求可以最近的看出裁判的地方,其实就是别的点产生矛盾最远的地方
                if(k > )
                    break;
            }             if(k == )
                printf("Impossible\n");
            else if(k > )
                printf("Can not determine\n");
            else
                printf("Player %d can be determined to be the judge after %d lines\n", q, p+);
        }
    }     return ;
}

最新文章

  1. 一个技术汪的开源梦 —— 基于 .Net Core 的公共组件之目录结构
  2. gulp-babel使用
  3. SAP&#160;MM常用表
  4. ruby中的reject和reject!
  5. hdu 4417 Super Mario 离线线段树
  6. Scrapy的shell命令(转)
  7. LINQ To XML的一些方法
  8. Mvc4.0添加商品到Cookie
  9. Jquery文本框值改变事件(支持火狐、ie)
  10. webservice接口调用存储过程返回失败
  11. 腾讯云数据库团队:MySQL AHI 实现解析
  12. LeetCode第[4]题(Java):Median of Two Sorted Arrays 标签:Array
  13. Spring IOC注入接口多实现解决
  14. Python探测主机端口是否存活
  15. TCP/IP协议(7):应用层
  16. Hadoop2源码分析-准备篇
  17. C语言浮点数存储结构
  18. IOS艺术字及简单的图文混排
  19. CodeForces - 725D Contest Balloons 贪心
  20. [Android] Content provider, ContentResolver

热门文章

  1. php模拟HTTP协议发送post请求方法
  2. Sublime Text插件之Emmet
  3. 未在本地计算机上注册“Microsoft.Jet.OLEDB.4.0”提供程序(Oledb)
  4. (转)dedecms插件开发简明教程
  5. c - 递归年龄
  6. Objective-C学习篇03—继承
  7. C#(WinForm)上传图片保存到数据库和从数据库读取图片显示到窗体
  8. ASP.NET 开发学习视频教程大全(共800集)
  9. JavaScript--数组--关联(hash)数组
  10. 50 Pow(x, n)(求x的n次方Medium)