题目

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君当然知道怎么做啦!但是他想考考你。

输入格式

包含至多5组测试数据。

第一行有一个正整数,表示数据的组数。

接下来每组数据第一行,有二个空格隔开的正整数\(n,m\),分别表示点的个数,操作个数。保证\(n,m< 40000\)。

接下来\(n-1\)行,每行三个整数\(x,y,z\),表示树的一条边。保证\(1<x<n, 1<y< n, 0 \le z \le 1\)。

接下来\(m\)行,每行一个操作,含义如前所述。保证一定只会出现前文中提到的两种格式。

对于操作\(0\),保证\(1 \le x \le n\) ;对于操作1,保证\(1 \le x \le n, 1 \le y \le n, 0 \le z \le 1\),保证树上存在一条边连接\(x\)和\(y\)。

输出格式

对于每组数据的每一个询问操作,输出一行“Boys win!”或者“Girls win!”。

输入样例

  1. 2
  2. 2 3
  3. 1 2 0
  4. 0 1
  5. 1 2 1 1
  6. 0 2
  7. 4 11
  8. 1 2 1
  9. 2 3 1
  10. 3 4 0
  11. 0 1
  12. 0 2
  13. 0 3
  14. 0 4
  15. 1 2 1 0
  16. 0 1
  17. 0 2
  18. 0 3
  19. 1 3 4 1
  20. 0 3
  21. 0 4

输出样例

  1. Boys win!
  2. Girls win!
  3. Girls win!
  4. Boys win!
  5. Girls win!
  6. Boys win!
  7. Boys win!
  8. Girls win!
  9. Girls win!
  10. Boys win!
  11. Girls win!

题解

在这棵树上,无论是操作黄色,绿色还是灰色节点,都会使蓝色边的状态翻转

所以显然,无论操作哪个节点,都会使这棵子树与根直接相连的那条边状态翻转

而由题意,只要这棵子树与根直接相连的边是1,都可以翻转,如果是0,则不一定.

假设最开始是1,男生翻转为0,假设还可以翻转,女生就翻转为1,由于此时这条边是1,所以男生一定可以继续翻转,翻转后是0,一直翻转下去,男生一定不会输,而女生终究会遇到全变成0的情况,所以男生一定会赢.

总结规律就是,如果这条边最开始是1,先手一定赢;反过来也成立,如果这条边最开始是0,先手一定输.

那么就可以通过统计和根节点直接相连的边的状态来计算答案了.

如果是1的边的个数是奇数,先手一定赢,反之先手一定输

代码

注意unordered_map内部实现是哈希表,查询比普通map快(\(O(1)\)),内部无序

  1. #include <bits/stdc++.h>
  2. using namespace std;
  3. const int maxn = 4e4 + 5, maxt = 4e4 + 1;
  4. unordered_map<int, int> a;
  5. inline int input() {int t;scanf("%d", &t);return t;}
  6. int main() {
  7. for (int t = input(); t--;) {
  8. int n = input(), m = input(), ans[maxn], key, x, y, z, u, v;
  9. vector<int> b[maxn];
  10. for (int i = 1; i < n; i++) {
  11. b[v=input()].push_back(u=input()),b[u].push_back(v);
  12. if (u > v) swap(u, v);
  13. a[u * maxt + v] = input();
  14. }
  15. for (int i = 1; i <= n; i++) {
  16. int s = 0;
  17. for (int j = 0; j < b[i].size(); j++) {
  18. int v = b[i][j], u = i;
  19. if (u > v) swap(u, v);
  20. s += a[u * maxt + v];
  21. }
  22. ans[i] = s & 1;
  23. }
  24. for (int i = 1; i <= m; i++) {
  25. if (key = input()) {
  26. if ((x=input()) > (y=input())) swap(x, y);
  27. if ((z=input()) != a[x * maxt + y]) ans[x] ^= 1, ans[y] ^= 1, a[x * maxt + y] = z;
  28. } else puts((ans[input()] & 1) ? "Girls win!" : "Boys win!");
  29. }
  30. }
  31. return 0;
  32. }

HDU 5963 朋友 题解的更多相关文章

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

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

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

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

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

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

  4. hdu 5963:朋友

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

  5. hdu 5963 朋友(2016ccpc 合肥站 C题)

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

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

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

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

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

  8. 【博弈】HDU - 5963 朋友

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

  9. 最简单的博弈论——HDU - 5963 朋友 (博弈)

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

随机推荐

  1. c#发布补丁

    日常开发维护项目中,可能会遇到发布后出现bug,或者忘记改配置文件等等问题,这个时候,可能就需要重新进行下发布,有的开发小伙伴可能会把编译后的代码文件整个替换.这样做虽然也可以实现发布,但是有几个弊端 ...

  2. 09 . Nginx配置LNMP和LNMT架构

    安装LNMP架构 环境清单 list CentOS7.3 proxysql-2.0.12-1-centos7.x86_64.rpm mysql-5.7.23-1.el7.x86_64.rpm-bund ...

  3. 2.3 sqlmap目录及结构

    2.3 sqlmap目录及结构Tips:此篇文章主要参考了<sqlmap从入门到精通>这本书中的相关具体细节,由于这本书作者完成的时间大概在2017年作用,所以我根据书中提到的信息再根据目 ...

  4. CRC循环冗余校验---模2除法解析

    关于模2除法,网上的人说了一大堆规则和原理,感觉很容易把小白绕进去,下面我只说怎么计算,不说其中的规则和原理.

  5. windows注册表删除右键菜单

    1.删除空白处右键菜单 HKEY_CLASSES_ROOT\Directory\background\shell HKEY_CLASSES_ROOT\Directory\background\shel ...

  6. (十)深入理解maven构建生命周期和各种plugin插件

    链接:https://blog.csdn.net/zhaojianting/article/details/80321488

  7. cc31a_demo--CppPrimer_静态成员与继承-在派生类中访问基类中的static成员的方法

    //*基类中的static成员,在整个继承层次中只有一个实例 //*在派生类中访问基类中的static成员的方法 //1.基类名::成员名 //2.子类名::成员名 //3.对象.成员名 //4.指针 ...

  8. 循序渐进VUE+Element 前端应用开发(11)--- 图标的维护和使用

    在VUE+Element 前端应用中,图标是必不可少点缀界面的元素,因此整合一些常用的图标是非常必要的,还好Element界面组件里面提供了很多常见的图标,不过数量不是很多,应该是300个左右吧,因此 ...

  9. 解除git文件处于lock状态方法

    解决办法: 去git文件夹下删除lock文件就可以

  10. 基于node的前端项目编译时内存溢出问题

    解决方法: CALL_AND_RETRY_LAST Allocation failed - JavaScript heap out of memory JavaScript堆内存不足,这里说的 Jav ...