题解 LNOI2014 LCA
题目:传送门
这道题根本不用lca,也没有部分分。。。
考虑求两个点xy的lca的深度。
我们将x到树根所有点的值都加1,然后查询y到根的和,其实就是lca的深度。
所以本题离线一下上树剖乱搞就可以了。
AC代码如下:
718ms 17348Kib
- #include <iostream>
- #include <cstdio>
- #include <vector>
- #include <algorithm>
- using namespace std;
- namespace StandardIO {
- template<typename T> inline void read (T &x) {
- x=;T f=;char c=getchar();
- for (; c<''||c>''; c=getchar()) if (c=='-') f=-;
- for (; c>=''&&c<=''; c=getchar()) x=x*+c-'';
- x*=f;
- }
- template<typename T> inline void write (T x) {
- if (x<) putchar('-'),x=-x;
- if (x>=) write(x/);
- putchar(x%+'');
- }
- }
- using namespace StandardIO;
- namespace Solve {
- const int MOD=;
- const int N=;
- struct Tree {
- int tree[N*],tag[N*];
- void pushdown (int pos,int left,int right) {
- if (tag[pos]) {
- int mid=(left+right)/;
- tree[pos*]+=(mid-left+)*tag[pos],tree[pos*]%=MOD;
- tree[pos*+]+=(right-mid)*tag[pos],tree[pos*+]%=MOD;
- tag[pos*]+=tag[pos],tag[pos*+]+=tag[pos],tag[pos*]%=MOD,tag[pos*+]%=MOD;
- tag[pos]=;
- }
- }
- void pushup (int pos) {
- tree[pos]=tree[pos*]+tree[pos*+],tree[pos]%=MOD;
- }
- void update (int pos,int left,int right,int L,int R,int add) {
- if (L<=left&&right<=R) {
- tree[pos]+=add*(right-left+),tree[pos]%=MOD;
- tag[pos]+=add,tag[pos]%=MOD;
- return;
- }
- pushdown(pos,left,right);
- int mid=(left+right)/;
- if (L<=mid) update(pos*,left,mid,L,R,add);
- if (R>mid) update(pos*+,mid+,right,L,R,add);
- pushup(pos);
- }
- int query (int pos,int left,int right,int L,int R) {
- if (L<=left&&right<=R) return tree[pos];
- pushdown(pos,left,right);
- int mid=(left+right)/;
- int ans=;
- if (L<=mid) ans+=query(pos*,left,mid,L,R),ans%=MOD;
- if (R>mid) ans+=query(pos*+,mid+,right,L,R),ans%=MOD;
- return ans;
- }
- } ljz;
- int n,q;
- vector<int>M[N];
- int dep[N],siz[N],fa[N],son[N];
- int ind[N],cnt;
- int top[N];
- void dfs1 (int now,int father) {
- dep[now]=dep[father]+,fa[now]=father,siz[now]=;
- for (register vector<int>::iterator i=M[now].begin(); i!=M[now].end(); i++) {
- if(*i==father) continue;
- dfs1(*i,now);
- siz[now]+=siz[*i];
- if (siz[*i]>siz[son[now]]) son[now]=*i;
- }
- }
- void dfs2(int now,int tp){
- top[now]=tp,ind[now]=++cnt;
- if (son[now]) dfs2(son[now],tp);
- for (register vector<int>::iterator i=M[now].begin(); i!=M[now].end(); i++) {
- if (*i==fa[now]||*i==son[now]) continue;
- dfs2(*i,*i);
- }
- }
- void upd (int x,int add){
- while (x) {
- ljz.update(,,n,ind[top[x]],ind[x],add);
- x=fa[top[x]];
- }
- }
- int que (int x) {
- int ans=;
- while (x) {
- ans+=ljz.query(,,n,ind[top[x]],ind[x]),ans%=MOD;
- x=fa[top[x]];
- }
- return ans;
- }
- int A[N];
- struct Q{
- int val,ind;
- Q () {val=ind=;}
- Q (int a,int b) :val(a),ind(b) {}
- friend bool operator < (Q a,Q b) {
- return a.val<b.val;
- }
- } s1[N],s2[N];
- int a1=,a2=;
- int Ans[N];
- inline void solve () {
- read(n),read(q);
- for (register int i=; i<=n; i++) {
- int a;
- read(a);
- M[a+].push_back(i);
- }
- dfs1(,);
- dfs2(,);
- for (register int i=; i<=q; i++) {
- int a,b,c;
- read(a),read(b),read(c);
- a++,b++,c++;
- A[i]=c;
- s1[i]=Q(a-,i),s2[i]=Q(b,i);
- }
- sort(s1+,s1+q+);
- sort(s2+,s2+q+);
- while (s1[a1].val==) a1++;
- for (register int i=; i<=n; i++) {
- upd(i,);
- while (s1[a1].val==i) {
- Ans[s1[a1].ind]-=que(A[s1[a1].ind])-MOD,Ans[s1[a1].ind]%=MOD;
- a1++;
- }
- while (s2[a2].val==i) {
- Ans[s2[a2].ind]+=que(A[s2[a2].ind]),Ans[s2[a2].ind]%=MOD;
- a2++;
- }
- }
- for (register int i=; i<=q; i++) {
- write(Ans[i]),putchar('\n');
- }
- }
- }
- using namespace Solve;
- int main () {
- // freopen(".in","r",stdin);
- // freopen(".out","w",stdout);
- solve();
- }
题解 LNOI2014 LCA的更多相关文章
- 【BZOJ3626】[LNOI2014]LCA 离线+树链剖分+线段树
[BZOJ3626][LNOI2014]LCA Description 给出一个n个节点的有根树(编号为0到n-1,根节点为0).一个点的深度定义为这个节点到根的距离+1.设dep[i]表示点i的深度 ...
- BZOJ 3626: [LNOI2014]LCA [树链剖分 离线|主席树]
3626: [LNOI2014]LCA Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 2050 Solved: 817[Submit][Status ...
- bzoj 3626 [LNOI2014]LCA(离线处理+树链剖分,线段树)
3626: [LNOI2014]LCA Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 1272 Solved: 451[Submit][Status ...
- bzoj 3626: [LNOI2014]LCA 离线+树链剖分
3626: [LNOI2014]LCA Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 426 Solved: 124[Submit][Status] ...
- BZOJ 3626: [LNOI2014]LCA( 树链剖分 + 离线 )
说多了都是泪啊...调了这么久.. 离线可以搞 , 树链剖分就OK了... -------------------------------------------------------------- ...
- 洛谷 P4211 [LNOI2014]LCA 解题报告
[LNOI2014]LCA 题意 给一个\(n(\le 50000)\)节点的有根树,询问\(l,r,z\),求\(\sum_{l\le i\le r}dep[lca(i,z)]\) 一直想启发式合并 ...
- P4211 [LNOI2014]LCA
P4211 [LNOI2014]LCA 链接 分析: 首先一种比较有趣的转化是,将所有点到1的路径上都+1,然后z到1的路径上的和,就是所有答案的deep的和. 对于多次询问,要么考虑有把询问离线,省 ...
- P4211 [LNOI2014]LCA LCT
P4211 [LNOI2014]LCA 链接 loj luogu 思路 多次询问\(\sum\limits_{l \leq i \leq r}dep[LCA(i,z)]\) 可以转化成l到r上的点到根 ...
- [BZOJ3626] [LNOI2014]LCA(树链剖分)
[BZOJ3626] [LNOI2014]LCA(树链剖分) 题面 给出一棵N个点的树,要求支持Q次询问,每次询问一个点z与编号为区间[l,r]内的点分别求最近公共祖先得到的最近公共祖先深度和.N, ...
随机推荐
- ES modules
注意:这篇文章讲的是正经的es module规范 及浏览器的实现!webpack项目中es module会被parse成commonjs,和这个没大关系! 总结: ES模块加载的主要过程: 构造 —— ...
- 03 Winform基础
补充: MD5加密 static void Main(string[] args) { string s = GetMD5("123"); Console.WriteLine(s) ...
- [BOI2011]MET-Meteors
题目:洛谷P3527. 题目大意:n个国家在某星球上建立了m个空间站(一个空间站只属于一个国家),空间站围成一个环.现在知道要下k天陨石,每天都在一个区间内下,每个点都下同样多的(若r>l,则说 ...
- 中国剩余定理(excrt) 模板
excrt板子题 #include <cmath> #include <cstdio> #include <cstring> #include <algori ...
- jquery 终止循环
jQuery中each类似于javascript的for循环 但不同于for循环的是在each里面不能使用break结束循环,也不能使用continue来结束本次循环,想要实现类似的功能就只能用ret ...
- ubuntu12.04开启Framebuffer
一.framebuffer概述 Framebuffer在Linux中是作为设备来实现的,它是对图形硬件的一种抽象,代表着显卡中的帧缓冲区(Framebuffer).通过Framebuffer设备,上层 ...
- Python 绘图与可视化 matplotlib(上)
参考链接:https://www.cnblogs.com/dudududu/p/9149762.html 更详细的:https://www.cnblogs.com/zhizhan/p/5615947. ...
- 2019-03-21 Python Request InsecureRequestWarning
问题: 使用Python3 requests发送HTTPS请求,已经关闭认证(verify=False)情况下,控制台会输出以下错误: InsecureRequestWarning: Unverifi ...
- openvswith Frequently Asked Questions
Open vSwitch <http://openvswitch.org> 参考地址:http://git.openvswitch.org/cgi-bin/gitweb.cgi?p=ope ...
- React 中的 refs的应用
React Refs React 支持一种非常特殊的属性 Ref ,你可以用来绑定到 render() 输出的任何组件上. 这个特殊的属性允许你引用 render() 返回的相应的支撑实例( back ...