题意:

给定一棵有根树,每个节点有一些石子,每次可以将不多于k的石子移动到父节点

修改一个点的石子数,插入一个点,询问某棵子树是否先手必胜


显然是一个阶梯Nim

每次最多取k个,找规律或者观察式子易发现就是$mod (k+1)$后的Nim

问题变为:

修改点权,插入点,询问某棵子树内某一深度的点权异或和

于是放大招了:伪$ETT$

真正的ETT貌似维护的是边,欧拉遍历序列也是边组成的序列

但我们用Splay来维护欧拉遍历的点的序列,入栈出栈时都加入队列,+1,-1,好像也叫括号序列

$build$过程中保存下每个点入栈和出栈对应的Splay上的节点编号,入栈正出栈负(一开始节点编号和序列编号是一样的)

本题的子树不需要根所以询问子树只要把那段区间splay出来就行了,需要根的找出区间的前驱后继splay他们就好了

加入新节点,分配两个dfs序编号给它,把新父亲和后继splay出来然后连上再更新就行了

#include <iostream>
#include <cstdio>
#include <cstring>
#include <algorithm>
#include <cmath>
using namespace std;
#define lc t[x].ch[0]
#define rc t[x].ch[1]
#define pa t[x].fa
#define pii pair<int, int>
#define MP make_pair
#define fir first
#define sec second
typedef long long ll;
const int N=1e5, INF=1e9;
inline int read(){
char c=getchar();int x=,f=;
while(c<''||c>''){if(c=='-')f=-; c=getchar();}
while(c>=''&&c<=''){x=x*+c-''; c=getchar();}
return x*f;
} int n, m, k, a[N], Q, op, x, y, z, id[N]; struct edge{int v, ne;} e[N<<];
int cnt, h[N];
inline void ins(int u, int v) {
e[++cnt]=(edge){v, h[u]}; h[u]=cnt;
}
int eul[N<<], dfc, deep[N];
pii dfn[N];
void dfs(int u) {
dfn[u].fir = ++dfc; eul[dfc]=u;
for(int i=h[u];i;i=e[i].ne)
deep[e[i].v] = deep[u]^, dfs(e[i].v);
dfn[u].sec = ++dfc; eul[dfc]=-u;
} struct meow{int ch[], fa, v, sg[], deep;} t[N<<];
int root;
inline int wh(int x) {return t[pa].ch[] == x;}
inline void update(int x) {
t[x].sg[] = t[lc].sg[]^t[rc].sg[];
t[x].sg[] = t[lc].sg[]^t[rc].sg[];
t[x].sg[t[x].deep] ^= t[x].v;
} inline void rotate(int x) {
int f=t[x].fa, g=t[f].fa, c=wh(x);
if(g) t[g].ch[wh(f)] = x; t[x].fa=g;
t[f].ch[c] = t[x].ch[c^]; t[t[f].ch[c]].fa=f;
t[x].ch[c^]=f; t[f].fa=x;
update(f); update(x);
}
inline void splay(int x, int tar) {
for(; pa!=tar; rotate(x))
if(t[pa].fa != tar) rotate(wh(x)==wh(pa) ? pa : x);
if(tar==) root=x;
} void build(int &x, int l, int r, int f) {
int mid = (l+r)>>; x=mid;
t[x].fa=f; t[x].deep = deep[abs(eul[mid])];
if(eul[mid]>) t[x].v = a[eul[mid]];
if(l<mid) build(lc, l, mid-, x);
if(mid<r) build(rc, mid+, r, x);
update(x);
} int Que(int u) {
int p = dfn[u].fir; splay(p, );
int x = dfn[u].sec; splay(x, p);
return t[lc].sg[deep[u]^] > ;
}
void ChaVal(int u, int d) {
int x = dfn[u].fir; splay(x, );
t[x].v = d; update(x);
}
inline int nex(int x) {
x = rc; while(lc) x = lc; return x;
}
void Add(int u, int v, int d) {
int p = dfn[u].fir; splay(p, );
int x = nex(p); splay(x, p); int a = ++dfc, b = ++dfc;
dfn[v] = MP(a, b);
t[a].ch[] = b; t[b].fa = a;
t[a].fa = x; t[x].ch[] = a;
t[a].v = d; t[a].deep = t[b].deep = deep[v] = deep[u]^;
update(a); update(x); update(p);
} int main() {
freopen("in","r",stdin);
n=read(); k=read()+;
for(int i=; i<=n; i++) a[i]=read()%k, id[i]=i;
for(int i=; i<n; i++) x=read(), y=read(), ins(x, y);
dfs(); build(root, , dfc, );
Q=read();
int meizi=, ans;
for(int i=; i<=Q; i++) {
op=read();
x=read()^meizi; x=id[x];
if(op==) ans=Que(x), meizi+=ans, puts(ans ? "MeiZ" : "GTY");
else {
y=read()^meizi;
if(op==) ChaVal(x, y%k);
else z=(read()^meizi)%k, Add(x, id[y]=++n, z);
} }
return ;
}

BZOJ 3729: Gty的游戏 [伪ETT 博弈论]【学习笔记】的更多相关文章

  1. BZOJ 3729 GTY的游戏

    伪ETT? 貌似就是Splay维护dfn = = 我们首先观察这个博弈 这个博弈直接%(l+1)应该还是很显然的 因为先手怎么操作后手一定能保证操作总数取到(l+1) 于是就变成阶梯Nim了 因为对于 ...

  2. BZOJ 3729 - Gty的游戏(Staircase 博弈+时间轴分块)

    题面传送门 介于自己以前既没有写过 Staircase-Nim 的题解,也没写过时间轴分块的题解,所以现在就来写一篇吧(fog 首先考虑最极端的情况,如果图是一条链,并且链的一个端点是 \(1\),那 ...

  3. BZOJ 3729 Gty的游戏 ——Splay

    很久很久之前,看到Treap,好深啊 很久之前看到Splay,这数据结构太神了. 之后学习了LCT. 然后看到Top-Tree就更觉得神奇了. 知道我见到了这题, 万物基于Splay 显然需要维护子树 ...

  4. 【BZOJ 3729】3729: Gty的游戏 (Splay维护dfs序+博弈)

    未经博主同意不得转载 3729: Gty的游戏 Time Limit: 20 Sec  Memory Limit: 128 MBSubmit: 448  Solved: 150 Description ...

  5. lua游戏开发实践指南学习笔记1

    本文是依据lua游戏开发实践指南做的一些学习笔记,仅用于继续自己学习的一些知识. Lua基础 1.  语言定义: 在lua语言中,标识符有非常大的灵活性(变量和函数名),只是用户不呢个以数字作为起始符 ...

  6. html5游戏引擎-Pharse.js学习笔记(一)

    1.前言 前几天随着flappy bird这样的小游戏的火爆,使我这种也曾了解过html5技术的js业余爱好者也开始关注游戏开发.研究过两个个比较成熟的html5游戏引擎,感觉用引擎还是要方便一些.所 ...

  7. BZOJ 2820: YY的GCD [莫比乌斯反演]【学习笔记】

    2820: YY的GCD Time Limit: 10 Sec  Memory Limit: 512 MBSubmit: 1624  Solved: 853[Submit][Status][Discu ...

  8. BZOJ 3786: 星系探索 [伪ETT]

    传送门 数据,标程 题意: 一颗有根树,支持询问点到根路径权值和,子树加,换父亲 欧拉序列怎么求路径权值和? 一个点的权值只会给自己的子树中的点贡献,入栈权值正出栈权值负,求前缀和就行了! 和上题一样 ...

  9. [BZOJ3786]星系探索(伪ETT)

    3786: 星系探索 Time Limit: 40 Sec  Memory Limit: 256 MBSubmit: 1638  Solved: 506[Submit][Status][Discuss ...

随机推荐

  1. A very hard Aoshu problem(dfs或者数位)

    题目连接:http://acm.hdu.edu.cn/showproblem.php?pid=4403 A very hard Aoshu problem Time Limit: 2000/1000 ...

  2. Python系列之入门篇——HDFS

    Python系列之入门篇--HDFS 简介 HDFS (Hadoop Distributed File System) Hadoop分布式文件系统,具有高容错性,适合部署在廉价的机器上.Python ...

  3. H5基础浏览器兼容性

    <!DOCTYPE HTML><html><body> <video width="320" height="240" ...

  4. 小白的Python之路 day5 模块XML特点和用法

    模块XML的特点和用法 一.简介 xml是实现不同语言或程序之间进行数据交换的协议,跟json差不多,但json使用起来更简单,不过,古时候,在json还没诞生的黑暗年代,大家只能选择用xml呀,至今 ...

  5. PHP面试题:HTTP中POST、GET、PUT、DELETE方式的区别

    HTTP定义了与服务器交互的不同的方法,最基本的是POST.GET.PUT.DELETE,与其比不可少的URL的全称是资源描述符,我们可以这样理解:url描述了一个网络上资源,而post.get.pu ...

  6. 急!!ftp登录错误,提示 530 not logged in,连接失败 ,,是怎么回事啊

    愤怒地青鸟 | 浏览 68533 次 发布于2017-04-11 00:44 最佳答案 核心提示:Ftp登陆不了是很经常碰到的事,很多人常常是不加分析就发贴询问.老实说,这样既浪费自己时间,又浪费别人 ...

  7. ThinkPhp5.0_文件上传

    ===================================================================== 路径: F:\wamp\www\public\uploads ...

  8. git log 查看指定文件的提交记录

    使用git log除了可以看整个仓库的提交记录外,还可以指定某个文件的提交记录. 1. 查看指定文件的历史提交记录 命令: git log -- <file> 说明:只需要指定文件名称. ...

  9. linux_vi快捷键

    vi有哪些快捷方式? 到行头: 0 ^ home 到行尾: $ shif+a(编辑模式) end 退出保存: wq . x .wq!(强制退出保存) 强制退出不保存: q! 光标移到文件最后一行: s ...

  10. org.apache.catalina.util.DefaultAnnotationProcessor cannot be cast to org.apache.AnnotationProcessor

    这几天来公司,公司的SVN坏掉了,然后项目还比较大,是一个分布式的,然后同事就把项目发我了.我在myeclipse里面导入项目了,把相应的jar包也建了个人的library导入了项目,现在项目不报错了 ...