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.父亲所在块满,自己单独开一个块 (貌似有更为优越的分块方式? 注意 ...
随机推荐
- C语言实现斐波那契数列
1.函数一用递归实现 2.函数二用循环实现 #include<stdio.h> #include<stdlib.h> #pragma warning(disable:4996) ...
- HyperLedger Fabric 1.4 超级账本简介(5.2)
超级账本(Hyperledger)是推动区块链跨行业应用的开源项目的总称,组织成员可以发起新的区块链项目,加入到超级账本项目(Hyperledger)中,但需要遵循Hyperledger的生命周期. ...
- win7 下安装oracle 11g出现错误: 启动服务出现错误 找不到服务OracleMTSRecoveryService
这种错误是在多次安装oracle都没有成功的情况下发生的. 正确安装oracle,是有前提条件的 1,安装最新的jdk,不是jre!!(并配好环境变量,在cmd中测试 java -version与ja ...
- 《UML大战需求分析》阅读笔记1
通过阅读本书的序和第一章,让我对于UML的理解更加深刻了,并且懂了怎样把你UML学的更好. 作者先让我们明白什么是UML,大概知道了UML各个图的形态和各种用途,然后再详细的介绍各个图怎样使用. UM ...
- Delphi中客户端获取数据库更新信息(更新条数)
1.SQL语句 from tb where xxx='XXX') //不存在,则插入数据 begin insert into tb(xxx) values('XXX') //这里自己定义,插入或更新都 ...
- laravel5.5jwt-auth的使用
laravel5.5 + jwt-auth:dev-develop 安装扩展 composer require tymon/jwt-auth:dev-develop --prefer-source 添 ...
- Python进程、线程、协程及IO多路复用
详情戳击下方链接 Python之进程.线程.协程 python之IO多路复用
- 为Zabbix配置RabbitMQ监控模板
RabbitMQ的配置参考 https://github.com/jasonmcintosh/rabbitmq-zabbix 简而言之,具体分为几个步骤: 1. 将脚本文件(scripts文件夹)和配 ...
- python xlrd处理表格常用方法
1.导入模块import xlrd2.打开Excel文件读取数据data = xlrd.open_workbook('excelFile.xls')3.使用技巧获取一个工作表 table = data ...
- c#程序中的AssemblyInfo.cs
在asp.net中有一个配置文件AssemblyInfo.cs主要用来设定生成的有关程序集的常规信息dll文件的一些参数,下面是默认的AssemblyInfo.cs文件的内容具体介绍 //是否符合公共 ...