朋友

Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others)
Total Submission(s): 215    Accepted Submission(s): 137

Problem Description
B君在围观一群男生和一群女生玩游戏,具体来说游戏是这样的:
给出一棵n个节点的树,这棵树的每条边有一个权值,这个权值只可能是0或1。 在一局游戏开始时,会确定一个节点作为根。接下来从女生开始,双方轮流进行 操作。
当一方操作时,他们需要先选择一个不为根的点,满足该点到其父亲的边权为1; 然后找出这个点到根节点的简单路径,将路径上所有边的权值翻转(即0变成1,1 变成0 )。
当一方无法操作时(即所有边的边权均为0),另一方就获得了胜利。
如果在双方均采用最优策略的情况下,女生会获胜,则输出“Girls win!”,否则输 出“Boys win!”。
为了让游戏更有趣味性,在每局之间可能会有修改边权的操作,而且每局游戏指 定的根节点也可能是不同的。
具体来说,修改边权和进行游戏的操作一共有m个,具体如下:

  • “0 x”表示询问对于当前的树,如果以x为根节点开始游戏,哪方会获得胜利。
  • “1 x y z ”表示将x和y之间的边的边权修改为z。

B君当然知道怎么做啦!但是他想考考你。

 
Input
包含至多5组测试数据。
第一行有一个正整数,表示数据的组数。
接下来每组数据第一行,有二个空格隔开的正整数n,m,分别表示点的个数,操 作个数。保证n,m< 40000。
接下来n-1行,每行三个整数x,y,z,表示树的一条边。保证1<x<n, 1<y< n, 0 <= z <= 1。
接下来m行,每行一个操作,含义如前所述。保证一定只会出现前文中提到的两 种格式。
对于操作0,保证1 <= x <= n ;对于操作1,保证1 <= x <= n, 1 <= y <= n, 0 <= z <= 1,保证树上存在一条边连接x和y。
 
Output
对于每组数据的每一个询问操作,输出一行“Boys win!”或者“Girls win!”。
 
Sample Input
2
2 3
1 2 0
0 1
1 2 1 1
0 2
411
1 2 1
2 3 1
3 4 0
0 1
0 2
0 3
0 4
1 2 1 0
0 1
0 2
0 3
1 3 4 1
0 3
0 4 
 
Sample Output
Boys win!
Girls win!
Girls win!
Boys win!
Girls win!
Boys win!
Boys win!
Girls win!
Girls win!
Boys win!
Girls win!
 
 
Source
 

  比赛的时候没有想出来,看到博弈就一直在想SG函数啥的,然后想想树上博弈怎么都不科学一定是道极难的,错过了。
  比赛完回来的时候车上又想了下,立刻就出来了。
  以某个结点作为根进行博弈的时候,无论翻转哪个结点,与根结点相连的边值是一定会翻转。所以只要考虑与根相连的结点话,两人的最优策略就出来了:若对方翻转后使一个与根结点相连的结点p与其之间边L的权值变为1,那自己就翻转以p为祖先的结点使得该条边L变回原状态(一定有这样的点,最差的情况就是翻转p)。对于与根相连的边来说,每次对手这样翻转你就一定能还原对方的操作。若对方翻转后使一个与根结点相连的结点p与其之间边L的权值变为0,或你不能再对L操作,或你也可以模仿对方的操作,但就如上所说,对方一定能还原你的操作。因此操作翻转了初始状态就为1的与跟相连的边L的操作最终不会被还原,是有效的,翻转初始状态为0的边L是无效的。所以初始与根相连的边权值为1的边的个数决定了输赢。若为偶数个,则后手胜,奇数个则先手胜。
  因此只要统计与每个点连接的边的个数的奇偶性就能得出胜负。
  代码如下;

 #include<cstdio>
#include<iostream>
#include<cstring>
#include<map>
#define clr(x) memset(x,0,sizeof(x))
using namespace std;
int tree[];
map<int,bool> treed;
int main()
{
int T,n,m,u,v,p,w;
scanf("%d",&T);
while(T--)
{
scanf("%d%d",&n,&m);
clr(tree);
treed.clear();
for(int i=;i<n;i++)
{
scanf("%d%d%d",&u,&v,&p);
if(p==)
{
tree[u]++;
tree[v]++;
treed[u*n+v]=;
treed[v*n+u]=;
}
}
for(int i=;i<=m;i++)
{
scanf("%d",&w);
if(w==)
{
scanf("%d%d%d",&u,&v,&p);
if(p== && treed[u*n+v]==)
{
tree[u]--;
tree[v]--;
treed[u*n+v]=;
treed[v*n+u]=;
} if(p== && treed[u*n+v]==)
{
tree[u]++;
tree[v]++;
treed[u*n+v]=;
treed[v*n+u]=;
}
}
if(w==)
{
scanf("%d",&p);
if(tree[p]%==)
printf("Girls win!\n");
else
printf("Boys win!\n");
}
}
}
return ;
}

hdu 5963 朋友(2016ccpc 合肥站 C题)的更多相关文章

  1. hdu 5961 传递 (2016ccpc 合肥站 A题)

    传递 Time Limit: 12000/6000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others)Total Submiss ...

  2. HDU 5963 朋友 (找规律,思维)

    HDU 5963 朋友 题目大意 B君在围观一群男生和一群女生玩游戏,具体来说游戏是这样的: 给出一棵n个节点的树,这棵树的每条边有一个权值,这个权值只可能是0或1. 在一局游戏开始时,会确定一个节点 ...

  3. HDU 5963 朋友 【博弈论】 (2016年中国大学生程序设计竞赛(合肥))

    朋友 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others) Problem Descr ...

  4. HDU - 5963 朋友(思维题)

    题干 B君在围观一群男生和一群女生玩游戏,具体来说游戏是这样的: 给出一棵n个节点的树,这棵树的每条边有一个权值,这个权值只可能是0或1. 在一局游戏开始时,会确定一个节点作为根.接下来从女生开始,双 ...

  5. hdu 5963:朋友

    刚看到这题时感觉是树上博弈,然后我开始用一维的数据找规律.发现在一维的树上,如果把各边的值合在一起当成一个二进制数,那么,ans只与奇偶性有关,于是,我提出了一个比较大胆的假设:若连接在root上的所 ...

  6. HDU 5963 朋友(找规律博弈)

    http://acm.hdu.edu.cn/showproblem.php?pid=5963 题意: 思路: 我们可以先只考虑单链,自己试几种案例就可以发现规律,只有与根相连的边为1时,只需要奇数次操 ...

  7. 【博弈】HDU - 5963 朋友

    题目 B君在围观一群男生和一群女生玩游戏,具体来说游戏是这样的: 给出一棵n个节点的树,这棵树的每条边有一个权值,这个权值只可能是0或1. 在一局游戏开始时,会确定一个节点作为根.接下来从女生开始,双 ...

  8. 【不知道怎么分类】HDU - 5963 朋友

    题目内容 B君在围观一群男生和一群女生玩游戏,具体来说游戏是这样的: 给出一棵n个节点的树,这棵树的每条边有一个权值,这个权值只可能是0或1. 在一局游戏开始时,会确定一个节点作为根.接下来从女生开始 ...

  9. HDU 5963 朋友(树+博弈)

    #include<vector> #include<cstdio> #include<cstring> #include<algorithm> #def ...

随机推荐

  1. HDU 2553 N皇后问题 (深搜)

    题目链接 Problem Description 在N*N的方格棋盘放置了N个皇后,使得它们不相互攻击(即任意2个皇后不允许处在同一排,同一列,也不允许处在与棋盘边框成45角的斜线上. 你的任务是,对 ...

  2. Tensorflow 2.0.0-alpha 安装 Linux系统

    1.TensorFlow2.0的安装测试 Linux Tensorflow Dev Summit 正式宣布 Tensorflow 2.0 进入 Alpha 阶段. 基于 Anaconda 创建环境一个 ...

  3. Django rest framework 的认证流程(源码分析)

    一.基本流程举例: urlpatterns = [ url(r'^admin/', admin.site.urls), url(r'^users/', views.HostView.as_view() ...

  4. spin_USACO

    Spinning Wheels1998 ACM NE Regionals Each of five opaque spinning wheels has one or more wedges cut ...

  5. (十九)git版本管理软件——搭建git服务器

    创建管理员git 为管理员用户添加sudo权限 生成管理员秘钥 设置管理员git提交账号和邮箱 下载安装gitolite 启动gitolite 添加项目版本库 添加项目成员 项目成员下载项目 gito ...

  6. c#使用selenium+Chromedriver参数配置

    using System; //添加selenium的引用 using OpenQA.Selenium.PhantomJS; using OpenQA.Selenium.Chrome; using O ...

  7. 81.Search in Rotated Sorted Array II---二分变形

    题目链接 题目大意:与33题类似,只是这里数组中有重复数值. 法一:解法与33题类似,只是这里要处理1,3,1,1,1这种情况,即有重复值时,mid与left和right都相等时,可以采用right- ...

  8. sqlserver2008 死锁解决方法及性能优化方法

    sqlserver2008 死锁解决方法及性能优化方法 原文: http://blog.csdn.net/kuui_chiu/article/details/48621939 十步优化SQL Serv ...

  9. UML基础

    UML基础系列:类图   类图描述系统中类的静态结构,它不仅定义系统中的类,描述类之间的联系,如关联.依赖.聚合等,还包括类的内部结构(类的属性和操作).类图描述的是静态关系,在系统的整个生命周期中都 ...

  10. mybatis 一级缓存和二级缓存

    1.默认是会话期内 一级session缓存 2.二级缓存: 引入二级缓存的jar, 配置 ehcache.xml, mapper.xml引入缓存<cache type="org.myb ...