OK,好的先看一下题意:

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。

—————————————————————————————————————————————————————————————————————————————

 sorry,代码在下面

题意应该比较好懂,一般人应该也知道这是博弈论。

但是我建议大家先模拟一下样例,方便理解。

但是具体怎么想呢?

博弈论一般都要先想什么时候是必胜状态。

同理:

这道题的必胜状态是什么呢?

当根节点所连的边中只有一条边的权值为1的话,那么肯定是 女生赢。

当根节点只连一条边,且边的权值是1,在这条边之后又连了很多条边,随便编的权值。

第一次女生翻转,那么第一条边的权值变成了0. 男生肯定不能翻转第一条边,

如果男生不能翻转,那么女生就赢了,如果男生还可以翻转,这时候第一条边又变成了1.

女生翻转又把第一条边变成了0.所以男生永远不可能翻转第一条边。

所以这种状态一定是女生赢。(根节点连了一条权值为1 的边。)

如果根节点连的边的权值和 为奇数,就是女生赢,反之就是男生赢。

是不是很简单。

然后是超级简单的代码。

提醒大家注意理解sum数组的含义。

 #include <cstdio>
#include <cstring>
using namespace std;
const int maxn=;
struct node{
int from,to,next,value;
}e[maxn<<];
int head[maxn],cnt,sum[maxn];
void add(int x,int y,int z){
e[++cnt].from=x;e[cnt].to=y;e[cnt].value=z;e[cnt].next=head[x];head[x]=cnt;
}
int main(){
//freopen("a.in","r",stdin);
int t;scanf("%d",&t);
while(t--){
memset(e,,sizeof(e));
memset(head,,sizeof(head));
memset(sum,,sizeof(sum));
cnt=;
int n,m;scanf("%d%d",&n,&m);
for(int i=;i<n;i++){
int x,y,z;scanf("%d%d%d",&x,&y,&z);
add(x,y,z);add(y,x,z);
sum[x]+=z;sum[y]+=z;
}
for(int i=;i<=m;i++){
int u;scanf("%d",&u);
if(u==){
int x;scanf("%d",&x);
int ans=sum[x];
if(ans%==)printf("Girls win!\n");
else printf("Boys win!\n");
}
else {
int x,y,z;scanf("%d%d%d",&x,&y,&z);
for(int k=head[x];k;k=e[k].next){
int v=e[k].to;
if(v==y){
sum[x]-=e[k].value;
sum[x]+=z;
e[k].value=z;
}
}
for(int k=head[y];k;k=e[k].next){
int v=e[k].to;
if(v==x){
sum[y]-=e[k].value;
sum[y]+=z;
e[k].value=z;break;
}
}
}
}
}
return ;
}

最简单的博弈论——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 朋友

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

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

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

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

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

  7. hdu 5963:朋友

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

  8. hdu 5693 朋友 博弈

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

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

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

随机推荐

  1. java实现第七届蓝桥杯寒假作业

    题目6.寒假作业 寒假作业 现在小学的数学题目也不是那么好玩的. 看看这个寒假作业: □ + □ = □ □ - □ = □ □ × □ = □ □ ÷ □ = □ (如果显示不出来,可以参见[图1. ...

  2. Linux文件搜索命令locate、which、grep详解

    命令locate详解 命令locate,其基本功能是在文件资料库中可以快速的搜索系统文件,占用系统资源很少,例如:locate my.cnf 还可以使用locate -i [文件名],不区分大小写进行 ...

  3. 【JAVA习题二十九】809*??=8*??+9*??+1 其中??代表的两位数,8*??的结果为两位数,9*??的结果为3位数。求??代表的两位数,及809*??后的结果。

    package erase; public class 八九与问好两位数的乘积和 { public static void main(String[] args) { int m,n;//m十位,n个 ...

  4. (二)JPA实体类主键生成策略

    在JPA中,配置实体类的主键的生成策略使用 @GeneratedValue @Id @Column(name = "id") @GeneratedValue(strategy = ...

  5. Git创建多个ssh key

    在使用git的时候,遇到需要创建多个ssh key的需求,一个用来git hub项目,一个用来git lab项目: 之前如果已将创建过一个ssh key,那么在创建第二个的时候,要修改默认名称,然后增 ...

  6. numpy中array数组对象的储存方式(n,1)和(n,)的区别

    资料:https://stackoverflow.com/questions/22053050/difference-between-numpy-array-shape-r-1-and-r 这篇文章是 ...

  7. CFS三层网络环境靶场实战

    一.环境搭建: ①根据作者公开的靶机信息整理 共有三个targets,目标是拿下三台主机权限,且是三层的网络环境,内网网段有192.168.22.0/24和192.168.33.0/24,添加两张仅主 ...

  8. 微信小程序踩坑之前端问题处理篇

    近期完成了一个小程序,自己做的前后端开发.真是惨哭我了o(╥﹏╥)o,下面几点希望大家可以避雷. 首先,想先介绍一下我遇到问题的解决思路: 1.先在postman调试接口,看数据获取是否正常, 2.在 ...

  9. C# 9.0 新特性之只读属性和记录

    阅读本文大概需要 2 分钟. 大家好,这是 C# 9.0 新特性系列的第 4 篇文章. 熟悉函数式编程的童鞋一定对"只读"这个词不陌生.为了保证代码块自身的"纯洁&quo ...

  10. Java并发编程-Java内存模型

    JVM内存结构与Java内存模型经常会混淆在一起,本文将对Java内存模型进行详细说明,并解释Java内存模型在线程通信方面起到的作用. 我们常说的JVM内存模式指的是JVM的内存分区:而Java内存 ...