Description

Solution

首先,每个节点上的权值可以等价于该节点上有(它的权的二进制位数+1)个石子,每次可以拿若干个石子但不能不拿。

然后就发现这和NIM游戏很像,就计算sg函数em(然而我并不会推)

如果您恰好看到这篇博,又恰好有空的话,欢迎探讨~

Code

#include<iostream>
#include<cstdio>
#include<cstring>
#include<cmath>
using namespace std;
typedef unsigned long long ull;
int n,x,y;
int num[];
ull t;
struct G{int y,nxt;}g[];int h[],tot=;
int dfs(int x,int fa)
{
int c=num[x],d=;
for (int i=h[x];i;i=g[i].nxt)
if (g[i].y!=fa) d^=dfs(g[i].y,x);
return c-=(c<=d);
}
int main()
{
while (scanf("%d",&n)!=EOF)
{
for (int i=;i<=n;i++){scanf("%llu",&t);num[i]=(int)log2(t)+;}
memset(h,,sizeof(h));tot=;
for (int i=;i<n;i++)
{
scanf("%d%d",&x,&y);x++;y++;
g[++tot]=G{y,h[x]};h[x]=tot;
g[++tot]=G{x,h[y]};h[y]=tot;
}
dfs(,)?printf("Alice\n"):printf("Marisa\n");
}
}

最新文章

  1. [开发笔记] Graph Databases on developing
  2. ContextMenuStrip 类
  3. HTML的checkbox和radio的美化
  4. oracle随机取数据
  5. ElasticSearch的 Query DSL 和 Filter DSL
  6. nmap所有参数详解
  7. 调皮的转义之addslashes
  8. Linux C 程序 字符串函数(12)
  9. FontDialog组件设置字体
  10. 网络流(最大流) CQOI 2015 BZOJ 3931 网络吞吐量
  11. Highcharts 点击反选
  12. CouchDB简单应用
  13. java基础知识汇总
  14. [LeetCode] Trim a Binary Search Tree 修剪一棵二叉搜索树
  15. Python3 找不到库
  16. Modelsimse10.4如何编译altera库文件以支持IP仿真
  17. vivalidi 一款由Web技术诞生的Web浏览器
  18. cordova打包webapp
  19. [Cqoi2014]数三角形——组合数
  20. php中显示数组与对象的实现代码

热门文章

  1. 关于 未在本地计算机上注册“VFPOLEDB.1” 的解决方案
  2. python下载指定的版本包
  3. Python学习---IO的异步[tornado模块]
  4. Python学习---Django关于POST的请求解析源码分析
  5. HTML基础标签的综合应用案例(颜色、斜体、加粗、下划线、a标签、无序列表、有序列表)
  6. October 09th 2017 Week 41st Monday
  7. 利用NET HUNTER建立一个自动文件下载的网络接入点
  8. 【理解】 Error 10053和 Error 10054
  9. 取消centOS7虚拟机锁屏
  10. Python内置函数.md