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

2
1 2
10 20
1
0 1 5

Sample Output

2

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的妹子树 树分块?瞎搞的更多相关文章

  1. bzoj 3720: Gty的妹子树 块状树

    3720: Gty的妹子树 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 412  Solved: 153[Submit][Status] Descr ...

  2. BZOJ 3744: Gty的妹子序列 【分块 + 树状数组 + 主席树】

    任意门:https://www.lydsy.com/JudgeOnline/problem.php?id=3744 3744: Gty的妹子序列 Time Limit: 20 Sec  Memory ...

  3. [bzoj 3720] Gty的妹子树 (树上分块)

    树上分块(块状树) Description 我曾在弦歌之中听过你, 檀板声碎,半出折子戏. 舞榭歌台被风吹去, 岁月深处尚有余音一缕-- Gty神(xian)犇(chong)从来不缺妹子-- 他来到了 ...

  4. BZOJ 3720: Gty的妹子树 [树上size分块]

    传送门 题意: 一棵树,询问子树中权值大于$k$的节点个数,修改点权值,插入新点:强制在线 一开始以为询问多少种不同的权值,那道CF的强制在线带修改版,直接吓哭 然后发现看错了这不一道树上分块水题.. ...

  5. BZOJ.3720.Gty的妹子树(树分块)

    题目链接 洛谷上惨遭爆零是为什么.. 另外这个树分块算法是假的. /* 插入删除只涉及一个数,故每次可以枚举一遍,而不是重构完后sort */ #include<cmath> #inclu ...

  6. bzoj 3744: Gty的妹子序列 主席树+分块

    3744: Gty的妹子序列 Time Limit: 15 Sec  Memory Limit: 128 MBSubmit: 101  Solved: 34[Submit][Status] Descr ...

  7. BZOJ 3744 Gty的妹子序列 (分块 + BIT)

    3744: Gty的妹子序列 Time Limit: 20 Sec  Memory Limit: 128 MBSubmit: 1931  Solved: 570[Submit][Status][Dis ...

  8. BZOJ 3744 Gty的妹子序列

    Description 我早已习惯你不在身边, 人间四月天 寂寞断了弦. 回望身后蓝天, 跟再见说再见-- 某天,蒟蒻Autumn发现了从 Gty的妹子树上掉落下来了许多妹子,他发现 她们排成了一个序 ...

  9. BZOJ 3720 gty的妹子树

    块状树裸题 块状树: 首先对树进行分块,分出的每一块都是一个连通块 通常的分块的方式如下: 1.父亲所在块不满,分到父亲所在块中 2.父亲所在块满,自己单独开一个块 (貌似有更为优越的分块方式? 注意 ...

随机推荐

  1. 多线程编程以及socket编程_Linux程序设计4chapter15

    看了Linux程序设计4中文版,学习了多线程编程和socket编程.本文的程序参考自Linux程序设计4的第15章. 设计了一个客户端程序,一个服务端程序.使用TCP协议进行数据传输. 客户端进程创建 ...

  2. 内存泄漏导致程序killed

    示例程序: #include<stdio.h> #include<unistd.h> int main() { ) { *]; } ; } 执行结果: 程序消耗完内存会被kil ...

  3. (数据科学学习手札34)多层感知机原理详解&Python与R实现

    一.简介 机器学习分为很多个领域,其中的连接主义指的就是以神经元(neuron)为基本结构的各式各样的神经网络,规范的定义是:由具有适应性的简单单元组成的广泛并行互连的网络,它的组织能够模拟生物神经系 ...

  4. Java——英文字母---18.10.11

    package lianxi;import java.io.*;import java.util.Scanner;public class file{  public static void main ...

  5. 基于Ubuntu Server 16.04 LTS版本安装和部署Django之(四):安装MySQL数据库

    基于Ubuntu Server 16.04 LTS版本安装和部署Django之(一):安装Python3-pip和Django 基于Ubuntu Server 16.04 LTS版本安装和部署Djan ...

  6. 1826: [JSOI2010]缓存交换

    1826: [JSOI2010]缓存交换 https://www.lydsy.com/JudgeOnline/problem.php?id=1826 分析: 简单的贪心,然后调啊调...最近怎么了,码 ...

  7. echarts的pie图中,各区块颜色的调整

    今天在学习使用echarts生成各种图表. 然后在使用pie图时出现我无论怎么更改代码中的颜色,pie图中各块的颜色都十分相近,几乎没法区别块与块之间的区别,如下图: 在下图中,除了其中一块的是红色的 ...

  8. 使用TFS需要注意的地方

    1. 用管理员添加了本地映射,然后用其他用户就添加不了映射,一定要先用管理员账户去把映射 删除掉: 2. 在正式使用TFS时,一定需要在VS工具的设置里面,设置一下,签出时自动获取最新的代码.(默认是 ...

  9. 破解PHPStrom 10 and Pycharm

    注册时选择 License server http://idea.lanyus.com/ 然后点击OK Pycharm -- License server http://idea.lanyus.com ...

  10. model的index无限次数执行导致stackOverFlow

    model的index无限次数执行导致stackOverFlow