bzoj3729 Gty的游戏

2024-05-11 23:48
文章标签 游戏 gty bzoj3729

本文主要是介绍bzoj3729 Gty的游戏,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

题目链接:bzoj3729
题目大意:
给定一棵有根树,每个节点有一些石子,每次可以将不多于L的石子移动到父节点,询问
将某个节点的子树中的石子移动到这个节点先手是否有必胜策略。
gty很快计算出了策略。
但gty的妹子十分机智,她决定修改某个节点的石子或加入某个新节点。
gty不忍心打击妹子,所以他将这个问题交给了你。
另外由于gty十分绅士,所以他将先手让给了妹子。
有三种操作类型
若为1,后跟一个数字v,表示询问在v的子树中做游戏先手是否必胜。
若为2,后跟两个数字x,y表示将节点x的石子数修改为y。
若为3,后跟三个数字u,v,x,表示为u节点添加一个儿子v,初始石子数为x。

题解:
博弈+splay
移石头这个就是经典的巴什博奕。每次移不超过L,对于每个节点的sg值就等于石子数mod(L+1).
要移到父亲节点什么的就是阶梯模型。若把子树根节点看作第0层的话,只有奇数层是“存在”的,因为若你把一些石子从偶数层移到奇数层,那么对方把它从奇数层移回去是等同的,因为最终会到0,即消失了,所以只考虑奇数层的移动偶数的不用管。即只考虑与子树根节点所处层数奇偶性不同的结点。
有加点修改操作什么的,用splay
维护四个值——子树中奇数层点的异或和,偶数层点的异或和,该点的石子数,所处层的奇偶性(都指的是原树中的信息,且奇偶性是对于整一棵树来说的)
把一个点拆成两个点分别表起始和结尾,然后以拆点后的中序遍历为关键值插入splay。比如在splay里转成1-1’,于是1的子树的所有信息就在splay中1’的左孩子那里了。

#include<cstdio>
#include<cstdlib>
#include<cstring>
#include<map>
#include<iostream>
#include<algorithm>
using namespace std;
#define maxn 400010map<int,int > id;
struct edge
{int y,next;
}a[maxn*2];int len,first[maxn];
void ins(int x,int y)
{len++;a[len].y=y;a[len].next=first[x];first[x]=len;
}
struct node
{int fa,son[2],a1,a2,x;bool dep;
}tr[maxn*2];int tot;
int nl[maxn],nr[maxn],w[maxn];
void updata(int x)
{int lc=tr[x].son[0],rc=tr[x].son[1];tr[x].a1=tr[lc].a1^tr[rc].a1;tr[x].a2=tr[lc].a2^tr[rc].a2;if (tr[x].dep) tr[x].a1^=tr[x].x;else tr[x].a2^=tr[x].x;
}
void rotate(int x)
{int y=tr[x].fa,z=tr[y].fa;int w=(tr[y].son[0]==x)?1:0;tr[y].son[1-w]=tr[x].son[w];if (tr[x].son[w]) tr[tr[x].son[w]].fa=y;if (z){if (tr[z].son[0]==y) tr[z].son[0]=x;if (tr[z].son[1]==y) tr[z].son[1]=x;}tr[x].fa=z;tr[x].son[w]=y;tr[y].fa=x;updata(y);updata(x);
}
void splay(int x,int fa)
{while (tr[x].fa!=fa){int y=tr[x].fa,z=tr[y].fa;if (z==fa) rotate(x);else{if ((tr[z].son[0]==y)==(tr[y].son[0]==x))rotate(y),rotate(x);else rotate(x),rotate(x);}}
}
void insert(int x,int fa)
{splay(fa,0);int r=tr[fa].son[1];while (tr[r].son[0]) r=tr[r].son[0];splay(r,fa);tr[r].son[0]=x;tr[x].fa=r;updata(r);updata(fa);
}
void lk(int x)
{tr[nl[x]].son[1]=nr[x];tr[nl[x]].x=w[x];tr[nr[x]].fa=nl[x];updata(nr[x]);updata(nl[x]);
}
void dfs(int x,int fa)
{for (int k=first[x];k!=-1;k=a[k].next){int y=a[k].y;if (y==fa) continue;tr[y].dep=!tr[x].dep;lk(y);insert(y,x);dfs(y,x);}
}int main()
{//freopen("a.in","r",stdin);//freopen("a.out","w",stdout);int n,m,mod,i,x,y,z,op,la;scanf("%d%d",&n,&mod);mod++;len=0;memset(first,-1,sizeof(first));for (i=1;i<=n;i++) {scanf("%d",&w[i]);w[i]%=mod;nl[i]=i;nr[i]=i+n;id[i]=i;}for (i=1;i<n;i++){scanf("%d%d",&x,&y);ins(x,y);ins(y,x);}tot=2*n;tr[0].dep=0;lk(1);tr[1].dep=1;dfs(1,0);scanf("%d",&m);la=0;while (m--){scanf("%d",&op);if (op==1){scanf("%d",&x);x^=la;x=id[x];splay(nl[x],0);splay(nr[x],nl[x]);int ans=0;if (!tr[x].dep) ans=tr[tr[nr[x]].son[0]].a1;else ans=tr[tr[nr[x]].son[0]].a2;if (ans==0) printf("GTY\n");else {printf("MeiZ\n");la++;}}else if (op==2){scanf("%d%d",&x,&y);x^=la;y^=la;x=id[x];y%=mod;splay(nl[x],0);if (tr[nl[x]].dep) tr[nl[x]].a1^=y^tr[nl[x]].x;else tr[nl[x]].a2^=y^tr[nl[x]].x;tr[nl[x]].x=y;}else{scanf("%d%d%d",&x,&y,&z);x^=la;y^=la;z^=la;z%=mod;x=id[x];id[y]=y=++n;nl[y]=++tot;nr[y]=++tot;tr[nl[y]].dep=!tr[nl[x]].dep;tr[nl[y]].x=z;tr[nr[y]].x=0;tr[nl[y]].fa=nl[x];tr[nr[y]].fa=nl[y];updata(nl[y]);updata(nr[y]);insert(nl[y],nl[x]);}}return 0;
}

这篇关于bzoj3729 Gty的游戏的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/981005

相关文章

国产游戏崛起:技术革新与文化自信的双重推动

近年来,国产游戏行业发展迅猛,技术水平和作品质量均得到了显著提升。特别是以《黑神话:悟空》为代表的一系列优秀作品,成功打破了过去中国游戏市场以手游和网游为主的局限,向全球玩家展示了中国在单机游戏领域的实力与潜力。随着中国开发者在画面渲染、物理引擎、AI 技术和服务器架构等方面取得了显著进展,国产游戏正逐步赢得国际市场的认可。然而,面对全球游戏行业的激烈竞争,国产游戏技术依然面临诸多挑战,未来的

火柴游戏java版

代码 /*** 火柴游戏* <p>* <li>有24根火柴</li>* <li>组成 A + B = C 等式</li>* <li>总共有多少种适合方式?</li>* <br>* <h>分析:</h>* <li>除去"+"、"="四根,最多可用火柴根数20根。</li>* <li>全部用两根组合成"1",最大数值为1111。使用枚举法,A和B范围在0~1111,C为A+B。判断</li>** @

国产游戏行业的崛起与挑战:技术创新引领未来

国产游戏行业的崛起与挑战:技术创新引领未来 近年来,国产游戏行业蓬勃发展,技术水平不断提升,许多优秀作品在国际市场上崭露头角。从画面渲染到物理引擎,从AI技术到服务器架构,国产游戏已实现质的飞跃。然而,面对全球游戏市场的激烈竞争,国产游戏技术仍然面临诸多挑战。本文将探讨这些挑战,并展望未来的机遇,深入分析IT技术的创新将如何推动行业发展。 国产游戏技术现状 国产游戏在画面渲染、物理引擎、AI

第四次北漂----挣个独立游戏的素材钱

第四次北漂,在智联招聘上,有个小公司主动和我联系。面试了下,决定入职了,osg/osgearth的。月薪两万一。 大跌眼镜的是,我入职后,第一天的工作内容就是接手他的工作,三天后他就离职了。 我之所以考虑入职,是因为 1,该公司有恒歌科技的freex平台源码,可以学学,对以前不懂的解解惑。 2,挣点素材钱,看看张亮002的视频,他用了6000多,在虚幻商城买的吸血鬼游戏相关的素材,可以玩两年。我

nyoj 1038 纸牌游戏

poj 的一道改编题,说是翻译题更恰当,因为只是小幅度改动。 一道模拟题,代码掌控能力比较好,思维逻辑清晰的话就能AC。 代码如下: #include<stdio.h>#include<string.h>#include<algorithm>using namespace std;struct node{char c[5];int rk;char da[5];int nu

如果出一个名叫白神话悟空的游戏

最近黑神话由于与原著不符引起了原著派的争议。 所以我在摸鱼的时候想到如果游科或者某个别的公司“痛改前非”不夹带私货完全复刻吴承恩百回版剧情制作一个“重走西游路”的游戏,会有一个什么样的销量?(设定为原著派已经多方渠道认证,此游戏的确没有夹带私货,绝大部分复刻了原著剧情) 游戏玩法我想了几类 超长线性有岔路蜈蚣形状地图,蜈蚣的腿部是探索区域和支线,重走西游路线,开篇就是开始取经前唐玄宗御弟cg

《黑暗之魂2:原罪学者》是什么类型的游戏 《黑暗之魂》可以在苹果Mac电脑上玩吗?

在宏大的世界观游戏中,《黑暗之魂2:原罪学者》脱颖而出,以其探索性和挑战性征服了全球玩家的心灵。下面我们来看看《黑暗之魂2:原罪学者》是什么类型的游戏,《黑暗之魂2:原罪学者》可以在苹果电脑玩吗的相关内容。 一、《黑暗之魂2:原罪学者》是什么类型的游戏 《黑暗之魂2:原罪学者》作为《黑暗之魂2》的增强版和重制版,是一款FromSoftware制作、BANDAI NAMCO和FromSoft

简单取石子游戏~博弈

很坑爹的小游戏,至于怎么坑爹,嘎嘎~自己研究去吧~! #include<stdio.h>#include<windows.h>#include<iostream>#include<string.h>#include<time.h>using namespace std;void Loc(int x,int y);/*定位光标*/void Welcome(); /*创建欢迎界面*/

黑神话:悟空》增加草地绘制距离MOD使游戏场景看起来更加广阔与自然,增强了游戏的沉浸式体验

《黑神话:悟空》增加草地绘制距离MOD为玩家提供了一种全新的视觉体验,通过扩展游戏中草地的绘制距离,增加了场景的深度和真实感。该MOD通过增加草地的绘制距离,使游戏场景看起来更加广阔与自然,增强了游戏的沉浸式体验。 增加草地绘制距离MOD安装 1、在%userprofile%AppDataLocalb1SavedConfigWindows目录下找到Engine.ini文件。 2、使用记事本编辑

Unity3D在2D游戏中获取触屏物体的方法

我们的需求是: 假如屏幕中一个棋盘,每个棋子是button构成的,我们希望手指或者鼠标在哪里,就显示那个位置的button信息。 网上有很多获取触屏物体信息的信息的方法如下面代码所示: Camera cam = Camera.main; // pre-defined...if (touch.phase == TouchPhase.Bagan)){ // 如果触控点状态为按下Ray