[LNOI2014]LCA(树链剖分)
题目:给你一棵树,给你n个询问,每个询问要求输出$\sum_{i=l}^{r}depth(LCA(i,z))$
细看看其实没有想象的那么难
大体思路:
1、对于每个询问,考虑打差分变成$\sum_{i=0}^{r}depth(LCA(i,z))-\sum_{i=0}^{l-1}depth(LCA(i,z))$
2、那么这里就是一个思考点了
如何表示$\sum_{i=0}^{p}depth(LCA(i,z))$?
我也不知道
这种时候就该换一个角度思考了
啥是深度?
不就是从根到他有几个点嘛
对于两个点i,j
从i向根的路径上+1
那么$query(root,j)$就是要求的$dep(LCA(i,j))$了
到这里思路就差不多出来了
①把每个询问分成两个,打差分
②排序询问,逐个插入$add(i,root,1)$
③每个询问查出$query(z,root)$
好了答案出来了
#include<cstdio> #include<algorithm> using std::sort; #define mo 201314 )%mo;} int n,m; struct sumireko { int to,ne; }e[]; ],ecnt; void addline(int f,int t) { e[++ecnt].to=t; e[ecnt].ne=he[f]; he[f]=ecnt; } ],hop[],size[],dson[],llen[],dep[],idn[],idnar; void dfs1(int x) { size[x]=; ; for(int i=he[x],t;i;i=e[i].ne) { t=e[i].to; dfs1(t); size[x]+=size[t]; if(lin<size[t]) { lin=size[t]; dson[x]=t; } } } void dfs2(int x,int top) { idn[x]=++idnar; hop[x]=top; llen[top]++; if(!dson[x]) return; dfs2(dson[x],top); for(int i=he[x],t;i;i=e[i].ne) { t=e[i].to; if(t==dson[x]) continue; dfs2(t,t); } } struct usami { int f,id,r,z; void set(int u,int i,int o,int p){f=u,id=i,r=o,z=p;} bool friend operator < (usami a,usami b) { return a.r<b.r; } }qqq[]; int qcnt; ]; struct segtree { ],del[],size[]; void build(int px,int pl,int pr) { if(pl==pr) { size[px]=; return; } ; build(px<<,pl,mid); build(px<<|,mid+,pr); size[px]=size[px<<]+size[px<<|]; } void fuckup(int px,int pl,int pr) { if(pl==pr) return; v[px]=v[px<<]+v[px<<|]; MOD(v[px]); } void fuckdown(int px,int pl,int pr) { if(pl==pr) return; if(del[px]) { v[px<<]+=del[px]*size[px<<];MOD(v[px<<]); del[px<<]+=del[px];MOD(del[px<<]); v[px<<|]+=del[px]*size[px<<|];MOD(v[px<<|]); del[px<<|]+=del[px];MOD(del[px<<|]); del[px]=; } } void add(int px,int pl,int pr,int vin,int ql,int qr) { if(ql<=pl&&qr>=pr) { v[px]+=vin*size[px]; del[px]+=vin; MOD(v[px]); MOD(del[px]); return; } fuckdown(px,pl,pr); ; ,pl,mid,vin,ql,qr); |,mid+,pr,vin,ql,qr); fuckup(px,pl,pr); } int query(int px,int pl,int pr,int ql,int qr) { if(ql<=pl&&qr>=pr) return v[px]; fuckdown(px,pl,pr); ; ; ,pl,mid,ql,qr),MOD(ret); |,mid+,pr,ql,qr),MOD(ret); return ret; } }tr; void inp(int x) { ]) { tr.add(,,n,,idn[hop[x]],idn[x]); x=fa[hop[x]]; } tr.add(,,n,,idn[],idn[x]); } void qq(int x,int id,int f) { ; ]) { prt+=tr.query(,,n,idn[hop[x]],idn[x]); MOD(prt); x=fa[hop[x]]; } prt+=tr.query(,,n,idn[],idn[x]); MOD(prt); ans[id]+=f*prt; MOD(ans[id]); } int main() { scanf("%d%d",&n,&m); ;i<n;i++) scanf("%d",&fa[i]),addline(fa[i],i); dep[]=; dfs1(); dfs2(,); tr.build(,,n); ,lin,rin,zin;i<=m;i++) { scanf("%d%d%d",&lin,&rin,&zin); qqq[++qcnt].,i,lin-,zin); qqq[++qcnt].,i,rin,zin); } sort(qqq+,qqq+qcnt+); ; ;i<=qcnt;i++) { while(tinar<qqq[i].r) {tinar++;inp(tinar);} qq(qqq[i].z,qqq[i].id,qqq[i].f); } ;i<=m;i++) printf("%d\n",ans[i]); ; }
精污代码慎入
[LNOI2014]LCA(树链剖分)的更多相关文章
- [BZOJ3626] [LNOI2014]LCA(树链剖分)
[BZOJ3626] [LNOI2014]LCA(树链剖分) 题面 给出一棵N个点的树,要求支持Q次询问,每次询问一个点z与编号为区间[l,r]内的点分别求最近公共祖先得到的最近公共祖先深度和.N, ...
- BZOJ 3626: [LNOI2014]LCA [树链剖分 离线|主席树]
3626: [LNOI2014]LCA Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 2050 Solved: 817[Submit][Status ...
- BZOJ 3626: [LNOI2014]LCA( 树链剖分 + 离线 )
说多了都是泪啊...调了这么久.. 离线可以搞 , 树链剖分就OK了... -------------------------------------------------------------- ...
- BZOJ3626[LNOI2014]LCA——树链剖分+线段树
题目描述 给出一个n个节点的有根树(编号为0到n-1,根节点为0).一个点的深度定义为这个节点到根的距离+1.设dep[i]表示点i的深度,LCA(i,j)表示i与j的最近公共祖先.有q次询问,每次询 ...
- bzoj 3626 : [LNOI2014]LCA (树链剖分+线段树)
Description 给出一个n个节点的有根树(编号为0到n-1,根节点为0).一个点的深度定义为这个节点到根的距离+1.设dep[i]表示点i的深度,LCA(i,j)表示i与j的最近公共祖先.有q ...
- 【bzoj3626】[LNOI2014]LCA 树链剖分+线段树
题目描述 给出一个n个节点的有根树(编号为0到n-1,根节点为0).一个点的深度定义为这个节点到根的距离+1.设dep[i]表示点i的深度,LCA(i,j)表示i与j的最近公共祖先.有q次询问,每次询 ...
- BZOJ 3626: [LNOI2014]LCA 树链剖分 线段树 离线
http://www.lydsy.com/JudgeOnline/problem.php?id=3626 LNOI的树链剖分题没有HAOI那么水,学到的东西还是很多的. 我如果现场写,很难想出来这种题 ...
- BZOJ 3626 [LNOI2014]LCA ——树链剖分
思路转化很巧妙. 首先把询问做差分. 然后发现加入一个点就把路径上的点都+1,询问的时候直接询问到根的路径和. 这样和原问题是等价的,然后树链剖分+线段树就可以做了. #include <map ...
- bzoj3626 [LNOI2014]LCA——树链剖分
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=3626 思路很巧妙,把区间换成前缀和相减: 把 l ~ r 到根路径上的点的点权都+1,然后 ...
- 洛谷 P4211 [LNOI2014]LCA (树链剖分+离线)
题目:https://www.luogu.org/problemnew/solution/P4211 相当难的一道题,其思想难以用言语表达透彻. 对于每个查询,区间[L,R]中的每个点与z的lca肯定 ...
随机推荐
- HDU 5783Divide the Sequence
Divide the Sequence Time Limit: 5000/2500 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Othe ...
- YTU 2633: P3 数钱是件愉快的事
2633: P3 数钱是件愉快的事 时间限制: 1 Sec 内存限制: 128 MB 提交: 387 解决: 215 题目描述 超市收银员的钱盒里,各种钞票总是按照面额分类整理,这样做可以提高效率 ...
- iOS10 国行iPhone联网权限问题处理
在iOS10上安装新App, 第一次打开时会询问用户"是否允许应用使用数据"(仅针对国行且需要连接移动网络的设备), 如下图所示, 在用户点击允许之前, App是无法联网的, 这意 ...
- js验证手机号,身份证,车牌号验证
js验证手机号 <input type="text" class="identificationno"> // 身份证号码为15位或者18位,15 ...
- 洛谷P3690 LCT模板
题目:https://www.luogu.org/problemnew/show/P3690 自己竟然从没有钻研过LCT上的连通性问题! 于是被最后一个点卡了,似乎因为 find 函数只能找出连通性而 ...
- Spring中AOP的两种代理方式(Java动态代理和CGLIB代理-转载
内容是摘抄的,不知最初的原作者,见谅 Java 动态代理.具体有如下四步骤: 通过实现 InvocationHandler 接口创建自己的调用处理器: 通过为 Proxy 类指定 ClassLoade ...
- 【BZOJ2525】[Poi2011]Dynamite(二分,树形dp)
[BZOJ2525][Poi2011]Dynamite Description Byteotian Cave的结构是一棵N个节点的树,其中某些点上面已经安置了炸.药,现在需要点燃M个点上的引线引爆所有 ...
- java io 文件下载
/** * 文件下载 * @param response * @param downloadPath * @param docName */ public void downLoadFile( Htt ...
- Y-C
1.asp.net服务控件生命周期 11个生命阶段 (1)初始化: 初始化在传入Web请求生命周期内所需的设置,.跟踪视图状态.页面框架通过默认方式引发Init事件,并调用OnInit()方法,控件开 ...
- 2017 Pycharm激活码
BIG3CLIK6F-eyJsaWNlbnNlSWQiOiJCSUczQ0xJSzZGIiwibGljZW5zZWVOYW1lIjoibGFuIHl1IiwiYXNzaWduZWVOYW1lIjoiI ...