bzoj 3720 Gty的妹子树 树分块?瞎搞
Gty的妹子树
Time Limit: 10 Sec Memory Limit: 128 MB
Submit: 2149 Solved: 781
[Submit][Status][Discuss]
Description
我曾在弦歌之中听过你,
檀板声碎,半出折子戏。
舞榭歌台被风吹去,
岁月深处尚有余音一缕……
Gty神(xian)犇(chong)从来不缺妹子……
他来到了一棵妹子树下,发现每个妹子有一个美丽度……
由于Gty很哲♂学,他只对美丽度大于某个值的妹子感兴趣。
他想知道某个子树中美丽度大于k的妹子个数。
某个妹子的美丽度可能发生变化……
树上可能会出现一只新的妹子……
维护一棵初始有n个节点的有根树(根节点为1),树上节点编号为1-n,每个点有一个权值wi。
支持以下操作:
0 u x 询问以u为根的子树中,严格大于x的值的个数。(u^=lastans,x^=lastans)
1 u x 把u节点的权值改成x。(u^=lastans,x^=lastans)
2 u x 添加一个编号为"当前树中节点数+1"的节点,其父节点为u,其权值为x。(u^=lastans,x^=lastans)
最开始时lastans=0。
Input
输入第一行包括一个正整数n(1<=n<=30000),代表树上的初始节点数。
接下来n-1行,每行2个整数u,v,为树上的一条无向边。
任何时刻,树上的任何权值大于等于0,且两两不同。
接下来1行,包括n个整数wi,表示初始时每个节点的权值。
接下来1行,包括1个整数m(1<=m<=30000),表示操作总数。
接下来m行,每行包括三个整数 op,u,v:
op,u,v的含义见题目描述。
保证题目涉及的所有数在int内。
Output
对每个op=0,输出一行,包括一个整数,意义见题目描述。
Sample Input
1 2
10 20
1
0 1 5
Sample Output
HINT
2017.9.28新加数据一组by GXZlegend,未重测
Source
传说中的树分块,但是会被暴力卡,我貌似没找出什么方法,
和根一起一起到达根号n就就分块,这个没什么用,会被菊花图卡掉的。
#include<cstring>
#include<cstdio>
#include<iostream>
#include<algorithm>
#include<cmath> #define N 60007
using namespace std;
inline int read()
{
int x=,f=;char ch=getchar();
while(!isdigit(ch)){if(ch=='-')f=-;ch=getchar();}
while(isdigit(ch)){x=(x<<)+(x<<)+ch-'';ch=getchar();}
return x*f;
} int n,m,block,ans,tot;
int a[N],fa[N],bl[N];
int cnt,hed[N],nxt[N<<],rea[N<<];
int Cnt,Hed[N],Nxt[N<<],Rea[N<<]; struct Node
{
int a[],siz;
void insert(int x){a[++siz]=x;}
void change(int x,int y)
{
int t=upper_bound(a+,a+siz+,x)-a;t--;
a[t]=y;
sort(a+,a+siz+);
}
int query(int x)
{
int t=upper_bound(a+,a+siz+,x)-a;
return siz-t+;
}
}blo[N];
inline void add(int u,int v)
{
nxt[++cnt]=hed[u];
hed[u]=cnt;
rea[cnt]=v;
}
inline void add_two_way(int u,int v)
{
add(u,v);
add(v,u);
}
inline void ins(int u,int v)
{
Nxt[++Cnt]=Hed[u];
Hed[u]=Cnt;
Rea[Cnt]=v;
}
void dfs(int u)
{
if (blo[bl[fa[u]]].siz==block)
blo[bl[u]=++tot].insert(a[u]),ins(bl[fa[u]],tot);
else blo[bl[u]=bl[fa[u]]].insert(a[u]);
for (int i=hed[u];i!=-;i=nxt[i])
{
int v=rea[i];
if (v==fa[u]) continue;
fa[v]=u,dfs(v);
}
}
void block_dfs(int u,int z)
{
ans+=blo[u].query(z);
for (int i=Hed[u];i!=-;i=Nxt[i])
{
int v=Rea[i];
block_dfs(v,z);
}
}
void solve(int u,int z)
{
if (a[u]>z) ans++;
for (int i=hed[u];i!=-;i=nxt[i])
{
int v=rea[i];
if (v==fa[u]) continue;
if (bl[v]==bl[u]) solve(v,z);
else block_dfs(bl[v],z);
}
}
int main()
{
memset(hed,-,sizeof(hed));
memset(Hed,-,sizeof(Hed));
n=read(),block=sqrt(n);
for (int i=;i<n;i++)
add_two_way(read(),read());
for (int i=;i<=n;i++) a[i]=read();
dfs();
for (int i=;i<=tot;i++)
sort(blo[i].a+,blo[i].a+blo[i].siz+); m=read();
for (int i=;i<=m;i++)
{
int opt=read(),x=read(),y=read();
x^=ans,y^=ans;
if (opt==)
{
ans=;
solve(x,y);
printf("%d\n",ans);
}
else if (opt==)
{
blo[bl[x]].change(a[x],y);
a[x]=y;
}
else
{
a[++n]=y,add_two_way(x,n),fa[n]=x;
if (blo[bl[x]].siz==block)
blo[bl[n]=++tot].insert(y),ins(bl[x],tot);
else
{
blo[bl[n]=bl[x]].insert(y);
sort(blo[bl[n]].a+,blo[bl[n]].a+blo[bl[n]].siz+);
}
}
}
}
bzoj 3720 Gty的妹子树 树分块?瞎搞的更多相关文章
- bzoj 3720: Gty的妹子树 块状树
3720: Gty的妹子树 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 412 Solved: 153[Submit][Status] Descr ...
- BZOJ 3744: Gty的妹子序列 【分块 + 树状数组 + 主席树】
任意门:https://www.lydsy.com/JudgeOnline/problem.php?id=3744 3744: Gty的妹子序列 Time Limit: 20 Sec Memory ...
- [bzoj 3720] Gty的妹子树 (树上分块)
树上分块(块状树) Description 我曾在弦歌之中听过你, 檀板声碎,半出折子戏. 舞榭歌台被风吹去, 岁月深处尚有余音一缕-- Gty神(xian)犇(chong)从来不缺妹子-- 他来到了 ...
- BZOJ 3720: Gty的妹子树 [树上size分块]
传送门 题意: 一棵树,询问子树中权值大于$k$的节点个数,修改点权值,插入新点:强制在线 一开始以为询问多少种不同的权值,那道CF的强制在线带修改版,直接吓哭 然后发现看错了这不一道树上分块水题.. ...
- BZOJ.3720.Gty的妹子树(树分块)
题目链接 洛谷上惨遭爆零是为什么.. 另外这个树分块算法是假的. /* 插入删除只涉及一个数,故每次可以枚举一遍,而不是重构完后sort */ #include<cmath> #inclu ...
- bzoj 3744: Gty的妹子序列 主席树+分块
3744: Gty的妹子序列 Time Limit: 15 Sec Memory Limit: 128 MBSubmit: 101 Solved: 34[Submit][Status] Descr ...
- BZOJ 3744 Gty的妹子序列 (分块 + BIT)
3744: Gty的妹子序列 Time Limit: 20 Sec Memory Limit: 128 MBSubmit: 1931 Solved: 570[Submit][Status][Dis ...
- BZOJ 3744 Gty的妹子序列
Description 我早已习惯你不在身边, 人间四月天 寂寞断了弦. 回望身后蓝天, 跟再见说再见-- 某天,蒟蒻Autumn发现了从 Gty的妹子树上掉落下来了许多妹子,他发现 她们排成了一个序 ...
- BZOJ 3720 gty的妹子树
块状树裸题 块状树: 首先对树进行分块,分出的每一块都是一个连通块 通常的分块的方式如下: 1.父亲所在块不满,分到父亲所在块中 2.父亲所在块满,自己单独开一个块 (貌似有更为优越的分块方式? 注意 ...
随机推荐
- Python3爬虫(十) 数据存储之非关系型数据库MongoDB
Infi-chu: http://www.cnblogs.com/Infi-chu/ 一.非关系型数据库NoSQL全程是Not Only SQL,非关系型数据库.NoSQL是基于键值对的,不需要经过S ...
- python基础之IO模型
IO模型分类 五种IO Model blocking IO 阻塞IO nonblocking IO 非阻塞IO IO multiplexing IO多路复用 signal driven IO 信号驱动 ...
- Grok Debugger本地安装(转载)
原文链接:http://fengwan.blog.51cto.com/508652/1758845 最近在使用ELK对日志进行集中管理,因为涉及到日志的规则经常要用到http://grokdebug. ...
- Bootstrap4用法
#Bootstrap4 ## 网格系统- .col- 针对所有设备- .col-sm- 平板 - 屏幕宽度等于或大于 576px- .col-md- 桌面显示器 - 屏幕宽度等于或大于 768px)- ...
- ip4addr_ntoa和不可重入函数
在网络中,有一个转换IP地址到ASIIC字符串的函数,该函数的返回值所指向的ASIIC字符串驻留在静态内存中,所以该函数不可重入. 通俗的讲,在多任务系统中,一个任务执行在调用运行这个函数的时候,其他 ...
- 搭建cvs服务器
http://zhangjunhd.blog.51cto.com/113473/78595 http://www.cnblogs.com/lee/archive/2008/10/22/1317226. ...
- mysql连接jdbc查询代码
package com.answer.test; import java.sql.DriverManager; import java.sql.ResultSet; import java.sql.S ...
- 理解JAVA常量池
下面是一些String相关的常见问题: String中的final用法和理解final StringBuffer a = new StringBuffer("111");final ...
- rails 中 preload、includes、Eager load、Joins 的区别
Rails 提供了四种不同加载关联数据的方法.下面就来介绍一下. 一.Preload Preload 是以附加一条查询语句来加载关联数据的 User.preload(:posts).to_a # =& ...
- MQTT 开源代理mosquitto的网络层封装相当sucks
最近学习MQTT协议,选择了当前比较流行的MQTT Broker “mosquitto”,但是在阅读代码过程中发现其网络底层库封装的相当差劲. 对于MQTT协议的变长头长度的读取上,基本上采取每次一个 ...