比赛的时候想到这题的大概做法,但由于卡别的水题。。。就赛后做了。。。

题意:给一个二叉树,每个结点有一个w[i],有3种操作,0 x表示左旋x,1 x表示右旋x,3 x表示询问x结点的价值,其中,价值为x子树结点的累加价值的累乘,其中,结点的累加价值为结点子树的Σw[i]。即询问是,∏Σw。

好像题意被我说得好渣好乱。。。。还是忽略上面2行吧。。。

首先,左旋右旋不影响中序遍历的index,即,可以把题目那2个图进行中序遍历,结果都是αXβYγ。由此,可以建立线段树。

而左旋右旋的过程模拟即可,可画示意图,将所有改变的一一写上。

要注意的是记得要改原本x跟父亲那条边,一开始没这个然后RE。。。。

#pragma comment (linker,"/STACK:102400000,102400000")
#include <cstdio>
#include <cstring>
#include <iostream>
using namespace std; #define ll long long
#define maxn 100010
#define mod 1000000007 int son[maxn][2];
int fa[maxn];
int idx[maxn];
int real[maxn];
int lr[maxn][2];
int w[maxn];
ll val[maxn];
ll mul[maxn<<2];
void dfs(int x,int& dfn){
val[x] = w[x];
if(son[x][0]) dfs(son[x][0],dfn), lr[x][0]=lr[son[x][0]][0], val[x]+=val[son[x][0]];
else lr[x][0]=dfn+1;
idx[x] = ++dfn;
real[dfn]=x;
if(son[x][1]) dfs(son[x][1],dfn), lr[x][1]=lr[son[x][1]][1], val[x]+=val[son[x][1]];
else lr[x][1]=dfn;
val[x]%=mod;
}
void pushUp(int u){
mul[u] = mul[u<<1]*mul[u<<1|1]%mod;
}
void build(int u,int l,int r){
if(l==r){
mul[u] = val[real[l]];
return ;
}
int mid = (l+r)>>1;
build(u<<1,l,mid);
build(u<<1|1,mid+1,r);
pushUp(u);
}
ll query(int u,int l,int r,int L,int R){
if(l==L&&r==R) return mul[u];
int mid = (l+r)>>1;
if(R<=mid) return query(u<<1,l,mid,L,R);
else if(L>mid) return query(u<<1|1,mid+1,r,L,R);
return query(u<<1,l,mid,L,mid)*query(u<<1|1,mid+1,r,mid+1,R)%mod;
}
void update(int u,int l,int r,int pos,ll v){
if(l==r){
mul[u] = v;
return ;
}
int mid = (l+r)>>1;
if(pos<=mid) update(u<<1,l,mid,pos,v);
else update(u<<1|1,mid+1,r,pos,v);
pushUp(u);
}
void LR(int x,int op,int n){
if(son[x][op]==0) return ;
int y = son[x][op];
int bb = son[y][op^1], cc=son[y][op];
son[x][op]=bb;
fa[bb]=x;
int xx=fa[x];
if(son[xx][0]==x) son[xx][0]=y;
else son[xx][1]=y;
fa[y]=xx;
son[y][op^1]=x;
fa[x]=y;
if(bb) lr[x][op] = lr[bb][op];
else lr[x][op] = idx[x];
lr[y][op^1] = lr[x][op^1];
if(bb) val[x] = val[x]-val[y]+val[bb];
else val[x] = val[x]-val[y];
if(cc) val[y] = val[x]+val[cc]+w[y];
else val[y] = val[x]+w[y];
update(1,1,n,idx[x],val[x]);
update(1,1,n,idx[y],val[y]);
}
int main(){
int t,n,m,ca=0;
scanf("%d",&t);
while(t--){
printf("Case #%d:\n",++ca);
scanf("%d%d",&n,&m);
memset(fa,0,sizeof(fa));
son[0][0]=son[0][1]=0;
for(int i=1;i<=n;++i){
scanf("%d%d%d",w+i,son[i],son[i]+1);
fa[son[i][0]]=fa[son[i][1]]=i;
}
int dfn=0;
dfs(1,dfn);
build(1,1,n);
for(int i=0;i<m;++i){
int op,x;
scanf("%d%d",&op,&x);
if(op==2) printf("%I64d\n",query(1,1,n,lr[x][0],lr[x][1]));
else LR(x,op,n);
}
}
return 0;
}

  

HDU 4942 Game on S♂play(线段树、模拟、扩栈)的更多相关文章

  1. hdu 5274 Dylans loves tree(LCA + 线段树)

    Dylans loves tree Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 131072/131072 K (Java/Othe ...

  2. HDU 3074.Multiply game-区间乘法-线段树(单点更新、区间查询),上推标记取模

    Multiply game Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Tot ...

  3. HDU 1394 Minimum Inversion Number(线段树求最小逆序数对)

    HDU 1394 Minimum Inversion Number(线段树求最小逆序数对) ACM 题目地址:HDU 1394 Minimum Inversion Number 题意:  给一个序列由 ...

  4. hdu_5818_Joint Stacks(线段树模拟)

    题目链接:hdu_5818_Joint Stacks 题意: 给你两个栈,多了个合并操作,然后让你模拟 题解: 很容易想到O(1)的单个栈操作,O(n)的合并操作,这样肯定超时,所以我们要将时间复杂度 ...

  5. 【CF280D】 k-Maximum Subsequence Sum ,线段树模拟费用流

    昨天考试被教育了一波.为了学习一下\(T3\)的科技,我就找到了这个远古时期的\(cf\)题(虽然最后\(T3\)还是不会写吧\(QAQ\)) 顾名思义,这个题目其实可以建成一个费用流的模型.我们用流 ...

  6. 2019牛客暑期多校训练营(第八场)E:Explorer(LCT裸题 也可用线段树模拟并查集维护连通性)

    题意:给定N,M,然后给出M组信息(u,v,l,r),表示u到v有[l,r]范围的通行证有效.问有多少种通行证可以使得1和N连通. 思路:和bzoj魔法森林有点像,LCT维护最小生成树.  开始和队友 ...

  7. [CSP-S模拟测试]:陶陶摘苹果(线段树维护单调栈)

    题目传送门(内部题116) 输入格式 第一行两个整数$n,m$,如题 第二行有$n$个整数表示$h_1-h_n(1\leqslant h_i\leqslant 10^9)$ 接下来有$m$行,每行两个 ...

  8. hdu 1556:Color the ball(线段树,区间更新,经典题)

    Color the ball Time Limit: 9000/3000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)To ...

  9. HDU 1394 Minimum Inversion Number(线段树/树状数组求逆序数)

    Minimum Inversion Number Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java ...

  10. HDU 5029 Relief grain(离线+线段树+启发式合并)(2014 ACM/ICPC Asia Regional Guangzhou Online)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5029 Problem Description The soil is cracking up beca ...

随机推荐

  1. thinkphp-许愿墙-3

    用jquery写异步传递的时候, 首先要判断表单中的输入是否为空: 如果有多个输入项, 应该, 分别的, 一步一步的来判断是否为空, 而不是用 and / or来复合判断! 同时如果为空, 应该将它设 ...

  2. plt和got

    最近在学习linux高级调试技术.下面就动态库连接这块做了一个实验 首先理解下plt是procedure linkage table,got是global offset table.got表中存放的是 ...

  3. STM32 之 NVIC(中断向量、优先级) 简述

    一.背景 需要使用STM32的CAN进行通信,经过一系列配置后,已可正常收发,还剩下一个CAN通信的错误处理.可错 误中断使能寄存器已经配置使能了,出错后就是无法进入"CAN1_SCE_IR ...

  4. 如何给wordpress外部链接自动添加nofollow

    wordpress多作者博客可以丰富网站的内容,但同时也会产生一些无关的链接,例如有些投机的人会考虑在文章中随意添加外部链接,如果你不想给这些外部链接传递权重,你需要给这些外部链接加上 rel=&qu ...

  5. docker镜象

    1.安装好docker后,用docker命令的时候有时候会报错:Post http:///var/run/docker.sock/v1.19/images/create?fromImage=ubunt ...

  6. MYSQL基础语句

    参考书籍< MySQL数据库基础与实例教程> --孔祥盛 SQL(structured query language)结构化查询语言,应用最为广泛的关系型数据库语言. MYSQL属于关系型 ...

  7. C++中的单例模式(转)

    单例模式也称为单件模式.单子模式,可能是使用最广泛的设计模式.其意图是保证一个类仅有一个实例,并提供一个访问它的全局访问点,该实例被所有程序模块共享.有很多地方需要这样的功能模块,如系统的日志输出,G ...

  8. 京东云、新浪微博等专家畅谈Docker未来格局:开放与竞争(下)

    在上次推送的文章中(传送门),田琪老师分享了他的DockerCon 2015峰会见闻.在“QCon高可用架构群”中,田老师分享之后,几位专家也参与了讨论.他们是: 闫国旗:京东资深架构师,京东架构技术 ...

  9. 分布式系统一致性算法 raft学习

    在学习MongoDB的过程中,有博客中写道其搭建复制集时使用了raft算法,经过简单地的搜索资料后,发现了一个特别好的网站资料.这个网站用动画的形式,非常清楚和详尽的解释了整个raft算法的精要和过程 ...

  10. 学习笔记:调用js文件冲突问题解决方案

    之前自己动手做了一个小网站,在实现过程中遇到了一个关于js文件调用冲突的问题. 具体问题描述如下:在index.html文件中引用了两个js文件,单独添加banner.js或者focus_pic.js ...