题解

当年LN还是有专门的省选题的,但是还不如没有

看到这道题,我就想到了一个清晰易懂,简单好写,代码优美的树链剖分线段树套主席树的\(O(q\log^{3}n)\)做法,且就5组数据出题人肯定是不会出题树剖卡不到上限……

但是我太菜了,我并不想实现这个算法……然后看了看一个神奇的\(O(n \log^{2} n)\)离线做法

我们注意到,实际上所求就是z到根节点路径上,每个点子树里的点下标在[l,r]的有多少个的和

首先区间都是可以拆成前缀和加减的,然后我们离线,往树链剖分加入每个节点,然后对于询问拆成两个前缀和的询问,排序依次查询回答即可

吐槽

1.模数没有任何意义,只是为了秀,还让人注意不到

2.我数组开小了,gg

代码

#include <iostream>
#include <cstdio>
#include <vector>
#include <algorithm>
//#define ivorysi
#define pb push_back
#define MAXN 50005
#define space putchar(' ')
#define enter putchar('\n')
using namespace std;
typedef long long int64;
template<class T>
void read(T &res) {
res = 0;char c = getchar();T f = 1;
while(c < '0' || c > '9') {
if(c == '-') f = -1;
c = getchar();
}
while(c >= '0' && c <= '9') {
res = res * 10 + c - '0';
c = getchar();
}
res *= f;
}
template<class T>
void out(T x) {
if(x < 0) putchar('-'),x = -x;
if(x >= 10) {
out(x / 10);
}
putchar('0' + x % 10);
}
const int MOD = 201314;
struct node {
int to,next;
}E[MAXN * 2];
struct qry {
int id,on,pos,z;
friend bool operator < (const qry &a,const qry &b) {
return a.pos < b.pos;
}
}Qry[MAXN * 2];
int head[MAXN],sumE,N,Q,siz[MAXN],top[MAXN],son[MAXN],fa[MAXN],dfn[MAXN],tot;
int ans[MAXN],tr[MAXN * 4],lz[MAXN * 4];
void add(int u,int v) {
E[++sumE].to = v;
E[sumE].next = head[u];
head[u] = sumE;
}
void dfs1(int u) {
siz[u]++;
for(int i = head[u] ; i ; i = E[i].next) {
int v = E[i].to;
if(v != fa[u]) {
fa[v] = u;
dfs1(v);
siz[u] += siz[v];
if(siz[v] > siz[son[u]]) son[u] = v;
}
}
}
void dfs2(int u) {
dfn[u] = ++tot;
if(!top[u]) top[u] = u;
if(son[u]) {top[son[u]] = top[u];dfs2(son[u]);}
for(int i = head[u] ; i ; i = E[i].next) {
int v = E[i].to;
if(v != fa[u] && v != son[u]) dfs2(v);
}
}
void addlazy(int u,int L,int R,int v) {
tr[u] = (tr[u] + (R - L + 1) * v) % MOD;lz[u] = lz[u] + v;
}
void push_down(int u,int L,int R) {
int mid = (L + R) >> 1;
if(lz[u]) {
addlazy(u << 1,L,mid,lz[u]);
addlazy(u << 1 | 1,mid + 1,R,lz[u]);
lz[u] = 0;
}
}
void Add(int u,int L,int R,int l,int r,int v) {
if(L == l && R == r) {addlazy(u,L,R,v);return;}
int mid = (L + R) >> 1;
push_down(u,L,R);
if(r <= mid) Add(u << 1,L,mid,l,r,v);
else if(l > mid) Add(u << 1 | 1,mid + 1,R,l,r,v);
else Add(u << 1,L,mid,l,mid,v),Add(u << 1 | 1,mid + 1,R,mid + 1,r,v);
tr[u] = (tr[u << 1] + tr[u << 1 | 1]) % MOD;
}
int Query(int u,int L,int R,int l,int r) {
if(L == l && R == r) return tr[u];
push_down(u,L,R);
int mid = (L + R) >> 1;
if(r <= mid) return Query(u << 1,L,mid,l,r);
else if(l > mid) return Query(u << 1 | 1,mid + 1,R,l,r);
else return Query(u << 1,L,mid,l,mid) + Query(u << 1 | 1,mid + 1,R,mid + 1,r);
}
void Init() {
read(N);read(Q);
for(int i = 2 ; i <= N ; ++i) {
int f;read(f);++f;
add(i,f);add(f,i);
}
int l,r,z;
for(int i = 1 ; i <= Q ; ++i) {
read(l);read(r);read(z);++l;++r;++z;
Qry[i * 2 - 1].id = i;Qry[i * 2 - 1].on = -1;Qry[i * 2 - 1].pos = l - 1;Qry[i * 2 - 1].z = z;
Qry[i * 2].id = i;Qry[i * 2].on = 1;Qry[i * 2].pos = r;Qry[i * 2].z = z;
}
sort(Qry + 1,Qry + 2 * Q + 1);
dfs1(1);
dfs2(1);
}
void Insert(int x) {
while(top[x] != 1) {
Add(1,1,N,dfn[top[x]],dfn[x],1);
x = fa[top[x]];
}
Add(1,1,N,dfn[top[x]],dfn[x],1);
}
int Query(int x) {
int res = 0;
while(top[x] != 1) {
res += Query(1,1,N,dfn[top[x]],dfn[x]) % MOD;
x = fa[top[x]];
}
res += Query(1,1,N,dfn[top[x]],dfn[x]);
return res % MOD;
}
void Solve() {
int p = 1;
while(Qry[p].pos < 1) ++p;
for(int i = 1 ; i <= N ; ++i) {
Insert(i);
while(Qry[p].pos == i) {
ans[Qry[p].id] += Qry[p].on * Query(Qry[p].z) % MOD;
++p;
}
}
for(int i = 1 ; i <= Q ; ++i) {
ans[i] = (ans[i] % MOD + MOD) % MOD;
out(ans[i]);enter;
}
}
int main() {
#ifdef ivorysi
freopen("f1.in","r",stdin);
#endif
Init();
Solve();
return 0;
}

【LOJ】#2558. 「LNOI2014」LCA的更多相关文章

  1. 【LOJ】#3046. 「ZJOI2019」语言

    LOJ#3046. 「ZJOI2019」语言 先orz zsy吧 有一个\(n\log^3n\)的做法是把树链剖分后,形成logn个区间,这些区间两两搭配可以获得一个矩形,求矩形面积并 然后就是对于一 ...

  2. 【LOJ】#2210. 「HNOI2014」江南乐

    LOJ#2210. 「HNOI2014」江南乐 感觉是要推sg函数 发现\(\lfloor \frac{N}{i}\rfloor\)只有\(O(\sqrt{N})\)种取值 考虑把这些取值都拿出来,能 ...

  3. 【LOJ】#3098. 「SNOI2019」纸牌

    LOJ#3098. 「SNOI2019」纸牌 显然选三个以上的连续牌可以把他们拆分成三个三张相等的 于是可以压\((j,k)\)为有\(j\)个连续两个的,有\(k\)个连续一个的 如果当前有\(i\ ...

  4. 【LOJ】#3103. 「JSOI2019」节日庆典

    LOJ#3103. 「JSOI2019」节日庆典 能当最小位置的值一定是一个最小后缀,而有用的最小后缀不超过\(\log n\)个 为什么不超过\(\log n\)个,看了一下zsy的博客.. 假如\ ...

  5. 【LOJ】#3102. 「JSOI2019」神经网络

    LOJ#3102. 「JSOI2019」神经网络 首先我们容易发现就是把树拆成若干条链,然后要求这些链排在一个环上,同一棵树的链不相邻 把树拆成链可以用一个简单(但是需要复杂的分类讨论)的树背包实现 ...

  6. 【LOJ】#3101. 「JSOI2019」精准预测

    LOJ#3101. 「JSOI2019」精准预测 设0是生,1是死,按2-sat连边那么第一种情况是\((t,x,1) \rightarrow (t + 1,y,1)\),\((t + 1,y, 0) ...

  7. 【LOJ】#3097. 「SNOI2019」通信

    LOJ#3097. 「SNOI2019」通信 费用流,有点玄妙 显然按照最小路径覆盖那题的建图思路,把一个点拆成两种点,一种是从这个点出去,标成\(x_{i}\),一种是输入到这个点,使得两条路径合成 ...

  8. 【LOJ】#3096. 「SNOI2019」数论

    LOJ#3096. 「SNOI2019」数论 如果\(P > Q\)我们把\(P\)和\(Q\)换一下,现在默认\(P < Q\) 这个时候每个合法的\(a_i\)都可以直接落到\(Q\) ...

  9. 【LOJ】#2239. 「CQOI2014」危桥

    LOJ#2239. 「CQOI2014」危桥 就是先把每条边正着连一条容量为2的边,反着连一条容量为2的边 显然如果只有一个人走的话,答案就是一个源点往起点连一条容量为次数×2的边,终点往汇点连一个次 ...

随机推荐

  1. Java基础-IO流对象之字符缓冲流(BufferedWriter与BufferedReader)

    Java基础-IO流对象之字符缓冲流(BufferedWriter与BufferedReader) 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.字符缓冲流 字符缓冲流根据流的 ...

  2. npm 5.4.2 更新后就不能用了

    今天刚,npm run dev 就出现更新提示,没多想就更了, 更新用了49S,下来npm 的所以命令包一个semer的插件 ... 最后下载新node 8.5覆盖安装, 就解决了, node 8.5 ...

  3. 外网IP和内网IP的区别

    这两天遇到一个bug,折腾的够呛,已经上线的项目,出现了个人登录不上的情况,瞬间整个人都不好了,首先找问题,在本地和测试服务器上都没问题,打包发布到正式环境就出现问题了,刚开始我看不了日志,日志要找别 ...

  4. Elasticsearch5.2.0部署过程的坑

    今天开工,在看ES时候发现前几天已经发布了5.2.0,就安装了一下,岂料安装完一直启动不了,可以说是一个bug. 报错: ERROR: bootstrap checks failed system c ...

  5. ipynb to pdf

    Q: 如何把jupyter notebook 转为 pdf 文档? A: 尝试了几种python包, 结果都没有成功. 包括: xhtml2pdf, 查看官方的介绍说用pandoc也是一种方法, 但是 ...

  6. 网页实战开发笔记之——最全面的HTML的头部信息介绍

    HTML中我们一般把<head></head>部分称为网页的头部.头部部分的内容虽然不会在页面中显示,但它能影响到搜索引擎对网页的收录和排序,以及网页的各种全局设置,可以说是至 ...

  7. iOS程序启动过程笔记

    CHENYILONG Blog 笔记 一.iOS程序的完整启动过程(有storyboard)1.先执行main函数,main内部会调用UIApplicationMain函数 2.UIApplicati ...

  8. Anaconda+django写出第一个web app(二)

    今天开始建立App中的第一个Model,命名为Tutorial. Model的定义在main文件夹下的models.py中通过类进行,我们希望Tutorial这个model包含三个属性:标题.内容和发 ...

  9. 问题 1476: [蓝桥杯][基础练习VIP]龟兔赛跑预测 (模拟)

    题目链接 题目描述 话说这个世界上有各种各样的兔子和乌龟,但是 研究发现,所有的兔子和乌龟都有一个共同的特点--喜欢赛跑.于是世界上各个角落都不断在发生着乌龟和兔子的比赛,小华对此很感兴趣,于是决定研 ...

  10. 如何在Maven和Gradle中配置使用Groovy 2.4与Spock 1.0

    如何在Maven和Gradle中配置使用Groovy 2.4与Spock 1.0 原文 https://dzone.com/articles/spock-10-groovy-24 翻译 hxfiref ...