BZOJ 3729 GTY的游戏

2023-12-19 03:40
文章标签 游戏 bzoj gty 3729

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

伪ETT?

貌似就是Splay维护dfn = =

我们首先观察这个博弈

这个博弈直接%(l+1)应该还是很显然的 因为先手怎么操作后手一定能保证操作总数取到(l+1)

于是就变成阶梯Nim了 因为对于先手从深度奇数点挪到深度偶数点后手接着可以把它挪回深度偶数点 所以就是典型的阶梯Nim

我们可以发现 只需要维护子树到一个点深度差为奇数的点的异或和就可以了

这个操作显然可以对整棵树按深度黑白染色 分别维护奇数层&偶数层即可(我这里用的是总和和奇数和

对于添加一个点那么我们直接把它挂到父亲后面就可以了 因为子树顺序对答案没有影响

然后调起来有点烦 这里学习到一个新的套路 就是新建一个Null节点 满足所有的边界条件 把它放在最后 这样就可以避免死循环的情况= =

然后这个思博样例显然没有卵用 需要自己造数据 然后我忘了要异或^mz 于是造出一堆不合法数据在那调 xtbl

写起来其实挺短的 和ETT没毛关系的样子。

//Love and Freedom.
#include<cstring>
#include<cmath>
#include<algorithm>
#include<cstdio>
#define ll long long
#define inf 20021225
#define N 100001
#define ls(x) t[x].son[0]
#define rs(x) t[x].son[1]
#define Null N-1
using namespace std;
int read()
{int s=0,f=1; char ch=getchar();while(ch<'0' || ch>'9')    {if(ch=='-') f=-1;ch=getchar();}while(ch>='0' && ch<='9')    s=s*10+ch-'0',ch=getchar();return f*s;
}
struct edge{int to,lt;}e[N<<1];
int in[N],cnt,poi,idfn[N];
void add(int x,int y)
{e[++cnt].to=y; e[cnt].lt=in[x]; in[x]=cnt;e[++cnt].to=x; e[cnt].lt=in[y]; in[y]=cnt;
}
struct node{int son[2],fa,val,sum,mn,sz;}t[N];
// val sg_odd sum sg_full mn min_dep sz
int dep[N],a[N],x,rt;
void pushup(int x)
{t[x].sz=t[ls(x)].sz+t[rs(x)].sz+1;t[x].sum=t[ls(x)].sum^t[rs(x)].sum^a[x];t[x].val=t[ls(x)].val^t[rs(x)].val^(dep[x]&1?a[x]:0);t[x].mn=min(dep[x],min(t[ls(x)].mn,t[rs(x)].mn));
}
void rotate(int x)
{int f=t[x].fa,gf=t[f].fa;int p=(rs(f)==x),k=p^1;t[gf].son[rs(gf)==f]=x;if(t[x].son[k])    t[t[x].son[k]].fa=f;t[f].son[p]=t[x].son[k]; t[x].fa=gf;t[x].son[k]=f; t[f].fa=x;pushup(f); pushup(x);
}
void splay(int x,int goal)
{while(t[x].fa!=goal){int f=t[x].fa,gf=t[f].fa;if(gf!=goal)(rs(f)==x)^(rs(gf)==f)?rotate(x):rotate(f);rotate(x);}if(!goal)    rt=x;
}
void dfs(int x,int f)
{if(f)    dep[x]=dep[f]+1;if(rt)    t[x].fa=rt,t[rt].son[1]=x;splay(x,0);for(int i=in[x];i;i=e[i].lt)    if(e[i].to!=f)dfs(e[i].to,x);
}
void insert(int x,int f,int v)
{splay(f,0); dep[x]=dep[f]+1; a[x]=v;t[t[f].son[1]].fa=x; t[x].son[1]=t[f].son[1];t[f].son[1]=x; t[x].fa=f; pushup(x); pushup(f);
}
int get(int x,int d)
{if(t[ls(x)].mn<=d)    return get(ls(x),d);else if(dep[x]<=d)    return x;else    return get(rs(x),d);
}
void put(int x)
{if(ls(x))    put(ls(x));printf("%d %d %d %d %d %d\n",x,ls(x),rs(x),t[x].fa,t[x].val,t[x].mn);if(rs(x))    put(rs(x));
}
int main()
{int n=read(),l=read(),x,y,v; dep[0]=t[0].mn=inf;for(int i=1;i<=n;i++)    a[i]=read()%(l+1);for(int i=1;i<n;i++)    x=read(),y=read(),add(x,y);dep[1]=1; dfs(1,0); t[Null].fa=rt; t[rt].son[1]=Null; splay(Null,0);int q=read(),mz=0;while(q--){int opt=read();if(opt==1){x=read()^mz; splay(x,0); int remx=x;//printf("%d %d\n",rs(x),remx);splay(get(rs(x),dep[x]),x); x=ls(rs(x));int ans=(dep[remx]&1)?t[x].sum^t[x].val:t[x].val;if(ans)    printf("MeiZ\n"),mz++;else    printf("GTY\n");}else if(opt==2){x=read()^mz; v=read()^mz;// printf("%d %d\n",x,v);splay(x,0); a[x]=v%(l+1); pushup(x);//put(x);
        }else{x=read()^mz; y=read()^mz; v=read()^mz;insert(y,x,v%(l+1));}}return 0;
}
View Code

 

转载于:https://www.cnblogs.com/hanyuweining/p/11301480.html

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



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

相关文章

Python开发围棋游戏的实例代码(实现全部功能)

《Python开发围棋游戏的实例代码(实现全部功能)》围棋是一种古老而复杂的策略棋类游戏,起源于中国,已有超过2500年的历史,本文介绍了如何用Python开发一个简单的围棋游戏,实例代码涵盖了游戏的... 目录1. 围棋游戏概述1.1 游戏规则1.2 游戏设计思路2. 环境准备3. 创建棋盘3.1 棋盘类

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

近年来,国产游戏行业发展迅猛,技术水平和作品质量均得到了显著提升。特别是以《黑神话:悟空》为代表的一系列优秀作品,成功打破了过去中国游戏市场以手游和网游为主的局限,向全球玩家展示了中国在单机游戏领域的实力与潜力。随着中国开发者在画面渲染、物理引擎、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、使用记事本编辑