题目链接

Problem Description

Alice and Bob are playing a game called 'Gameia ? Gameia !'. The game goes like this :

0. There is a tree with all node unpainted initial.

  1. Because Bob is the VIP player, so Bob has K chances to make a small change on the tree any time during the game if he wants, whether before or after Alice's action. These chances can be used together or separate, changes will happen in a flash. each change is defined as cut an edge on the tree.
  2. Then the game starts, Alice and Bob take turns to paint an unpainted node, Alice go first, and then Bob.
  3. In Alice's move, she can paint an unpainted node into white color.
  4. In Bob's move, he can paint an unpainted node into black color, and what's more, all the other nodes which connects with the node directly will be painted or repainted into black color too, even if they are white color before.
  5. When anybody can't make a move, the game stop, with all nodes painted of course. If they can find a node with white color, Alice win the game, otherwise Bob.

    Given the tree initial, who will win the game if both players play optimally?

Input

The first line of the input gives the number of test cases T; T test cases follow.

Each case begins with one line with two integers N and K : the size of the tree and the max small changes that Bob can make.

The next line gives the information of the tree, nodes are marked from 1 to N, node 1 is the root, so the line contains N-1 numbers, the i-th of them give the farther node of the node i+1.

Limits

T≤100

1≤N≤500

0≤K≤500

1≤Pi≤i

Output

For each test case output one line denotes the answer.

If Alice can win, output "Alice" , otherwise "Bob".

Sample Input

2

2 1

1

3 1

1 2

Sample Output

Bob

Alice

题意:

Alice和Bob玩一个游戏,一开始有一颗有n个节点并且没有颜色的树,Bob和Alice分别对树上的节点进行染色,Alice每次将一个没有颜色的点涂成白色,Bob每次将一个没有颜色的点涂成黑色,并且可以将与涂上黑色的这个点直接相邻的点变为黑色,假如最后树被涂满之后还存在白色点,Alice赢,否则Bob赢。Bob还有一个特权,可以在任意时候,删除任意一条边,这样的特权可以使用k次。

分析:

首先当有一条长度大于等于3的链的时候,Alice一定可以获胜。可以找出来3 和 4 的时候这个结论是成立的。(3的时候先染中间那个点,4的时候先染最后一个点)当长度大于4的时候,Alice可以染倒数第二个点,那么Bob只能染最后一个点,否则他必输。这样就相当于将链的长度减小了2。那么接下去一定会变成3或4的链,Alice必胜。

实际上如果一个相连通的点集元素大于等于3的时候,Alice都是必胜的。因为如果是一棵树Alice可以用上述方式,每次染一个叶子节点的父节点,Bob只能染这个叶子结点。那么最后就会化成链或者只剩一个节点,那么她必胜。

对于一个节点连同它所有的子节点的个数如果是奇数的话,那么这样无论如何Alice都会赢,每次Alice先染白一个点,然后每次Bob涂的时候只有涂这个节点的子节点才能将这个节点再涂成黑色,这样他俩一轮下来只能涂两个,这样下来即使每个节点都是有两个子节点,最后被涂成白色的子节点个数最多为n/2-1个。

如果Bob的特权次数小于这个数的话,必然也是Alice赢。

如果为偶数的话,并且可以将这个树划分为所有都是只有两个点相连的话,Bob赢。

代码:

#include<stdio.h>
#include<vector>
using namespace std;
vector<int>vt[505];
int size[505];
int flag=0; void dfs(int u)
{
int num=0;///奇数节点的个数
size[u]=1;
for(int i=0; i<vt[u].size(); i++)///递归所有的子节点
{
int to=vt[u][i];
dfs(to);
size[u]+=size[to];
if(size[to]%2==1)num++;///为奇数的节点(包括单独的叶子节点),Alice回赢
}
if(num>=2)flag=1;///这样的话也就相当于只有有两个节点的话,Bob才会赢
}
int main()
{
int T;
scanf("%d",&T);
while(T--)
{
for(int i=0; i<505; i++)vt[i].clear();
int n,k;
scanf("%d%d",&n,&k);
for(int i=2; i<=n; i++)
{
int f;
scanf("%d",&f);
vt[f].push_back(i);
}
flag=0;
if(n%2==1||n/2-1>k)///奇数个或者特权数不够用,必定Alice赢
printf("Alice\n");
else///节点个数为偶数个并且特权个数足够用
{
dfs(1);
if(flag==1)
printf("Alice\n");
else
printf("Bob\n");
}
}
}

2017ACM暑期多校联合训练 - Team 6 1010 HDU 6105 Gameia (博弈)的更多相关文章

  1. 2017ACM暑期多校联合训练 - Team 9 1010 HDU 6170 Two strings (dp)

    题目链接 Problem Description Giving two strings and you should judge if they are matched. The first stri ...

  2. 2017ACM暑期多校联合训练 - Team 7 1010 HDU 6129 Just do it (找规律)

    题目链接 Problem Description There is a nonnegative integer sequence a1...n of length n. HazelFan wants ...

  3. 2017ACM暑期多校联合训练 - Team 4 1004 HDU 6070 Dirt Ratio (线段树)

    题目链接 Problem Description In ACM/ICPC contest, the ''Dirt Ratio'' of a team is calculated in the foll ...

  4. 2017ACM暑期多校联合训练 - Team 9 1005 HDU 6165 FFF at Valentine (dfs)

    题目链接 Problem Description At Valentine's eve, Shylock and Lucar were enjoying their time as any other ...

  5. 2017ACM暑期多校联合训练 - Team 8 1006 HDU 6138 Fleet of the Eternal Throne (字符串处理 AC自动机)

    题目链接 Problem Description The Eternal Fleet was built many centuries ago before the time of Valkorion ...

  6. 2017ACM暑期多校联合训练 - Team 8 1002 HDU 6134 Battlestation Operational (数论 莫比乌斯反演)

    题目链接 Problem Description The Death Star, known officially as the DS-1 Orbital Battle Station, also k ...

  7. 2017ACM暑期多校联合训练 - Team 8 1011 HDU 6143 Killer Names (容斥+排列组合,dp+整数快速幂)

    题目链接 Problem Description Galen Marek, codenamed Starkiller, was a male Human apprentice of the Sith ...

  8. 2017ACM暑期多校联合训练 - Team 8 1008 HDU 6140 Hybrid Crystals (模拟)

    题目链接 Problem Description Kyber crystals, also called the living crystal or simply the kyber, and kno ...

  9. 2017ACM暑期多校联合训练 - Team 7 1009 HDU 6128 Inverse of sum (数学计算)

    题目链接 Problem Description There are n nonnegative integers a1-n which are less than p. HazelFan wants ...

随机推荐

  1. Alpha - Postmortem

    Alpha - Postmortem NewTeam 2017/11/18 目录 设想和目标 计划 资源 变更管理 设计/实现 测试/发布 团队角色.管理.合作 总结 设想和目标 返回目录 1. 软件 ...

  2. Scrum冲刺博客汇总

    第一篇 Scrum冲刺博客 http://www.cnblogs.com/LZTZ/p/8886296.html 第二篇 Scrum冲刺博客 http://www.cnblogs.com/LZTZ/p ...

  3. 【vue】vue组件的自定义事件

    父组件: <template> <div> <my-child abcClick="sayHello"></my-child> &l ...

  4. windows下的coreseek安装及PHP调用入门

    转载:http://zhan.renren.com/longmensoft?gid=3602888498043096197&checked=true 把我的运行环境简单说一下:windows ...

  5. word批量转pdf文件快捷方法。

    最近在工作中因为要遇到大量的Word文件转化为PDF文件来实现平台的迁移.但是由于文件太多,手动很费力,想到了用代码的方式: 复制下面的代码,保存的记事本,另存为vbs文件:然后把这个vbs文件放到你 ...

  6. android Eclipse there no select

    点mainactivity类 右键  run as 进行 配置 就可运行

  7. MVC4中control的增删改查

    public class TestController : Controller { private LeaveEntities db = new LeaveEntities(); // // GET ...

  8. P1939 【模板】矩阵加速(数列)

    题目描述 a[1]=a[2]=a[3]=1 a[x]=a[x-3]+a[x-1] (x>3) 求a数列的第n项对1000000007(10^9+7)取余的值. 输入输出格式 输入格式: 第一行一 ...

  9. 【刷题】BZOJ 2434 [Noi2011]阿狸的打字机

    Description 阿狸喜欢收藏各种稀奇古怪的东西,最近他淘到一台老式的打字机.打字机上只有28个按键,分别印有26个小写英文字母和'B'.'P'两个字母. 经阿狸研究发现,这个打字机是这样工作的 ...

  10. Unity3D for VR 学习(6): 再次温故知新-3D数学

    一年前,系统学习过3D数学,并记录了一篇博客<C#程序员整理的Unity 3D笔记(十):Unity3D的位移.旋转的3D数学模型>. 一年后,再次温习之. 坐标系:Unity3D使用左手 ...