洛谷题目传送门

仍然是一个板子。

不过蒟蒻去学了一下BIT维护区间修改区间求和,常数果真十分优秀

设数列为\(a_i\),差分数组\(d_ i=a_ i-a_ {i-1}\),前缀和\(s_i=\sum\limits_ {j=1}^ia_ j\)

显然有\(a_ i=\sum\limits_ {j=1}^id_ j\)

于是大力展开得到

\[s_i=\sum\limits_{j=1}^i(i-j+1)d_j
\]

\[s_i=(i+1)\sum\limits_{i=1}^jd_j-\sum\limits_{j=1}^ijd_j
\]

用BIT维护\(d_i\)和\(id_i\)的前缀和即可。

#include<cstdio>
#define RG register
#define R RG int
#define G if(++ip==ie)fread (ip=ibuf,1,L,stdin)
#define P(C) *op=C;if(++op==oe)fwrite(op=obuf,1,L,stdout)
typedef long long LL;
const int N=1e5+9,M=N<<1,L=1<<19;
char ibuf[L],*ie=ibuf+L,*ip=ie-1,obuf[L],*oe=obuf+L,*op=obuf;
int YL,n,p,a[N],he[N],ne[M],to[M],f[N],s[N],id[N],pr[N],dep[N],top[N],d[N],e[N];
inline int in(){
G;while(*ip<'-')G;
R x=*ip&15;G;
while(*ip>'-'){(x*=10)+=*ip&15;G;}
return x;
}
void out(R x){
if(x>9)out(x/10);
P(x%10|'0');
}
inline void swap(R&x,R&y){
R z=x;x=y;y=z;
}
void dfs1(R x,R y){
s[x]=1;
dep[x]=dep[f[x]=y]+1;
for(R i=he[x];i;i=ne[i])
if(to[i]!=y)dfs1(to[i],x);
s[y]+=s[x];
if(s[pr[y]]<s[x])pr[y]=x;
}
void dfs2(R x,R y){
top[x]=y;
d[id[x]=++p]=a[x];
if(!pr[x])return;
dfs2(pr[x],y);
for(R i=he[x];i;i=ne[i])
if(!id[to[i]])dfs2(to[i],to[i]);
}
inline void mdf(R*d,R i,R v){
for(;i<=n;i+=i&-i)(d[i]+=v)%=YL;
}
inline void upd(R l,R r,R v){
mdf(d,l,v);mdf(e,l,(LL)v*l%YL);v=YL-v;
mdf(d,r,v);mdf(e,r,(LL)v*r%YL);
}
inline int qry(R*d,R i){
R v=0;
for(;i;i-=i&-i)(v+=d[i])%=YL;
return v;
}
inline int ask(R l,R r){
return (((LL)(r+1)*qry(d,r)-qry(e,r)-(LL)(l+1)*qry(d,l)+qry(e,l))%YL+YL)%YL;
}
int main(){
n=in();R m=in(),rt=in(),i,x,y,z,ans;YL=in();
for(i=1;i<=n;++i)a[i]=in();
for(i=1;i<n;++i){
x=in();y=in();
ne[++p]=he[x];to[he[x]=p]=y;
ne[++p]=he[y];to[he[y]=p]=x;
}
p=0;dfs1(rt,0);dfs2(rt,rt);
for(i=n;i;--i){
d[i]=((d[i]-d[i-1])%YL+YL)%YL;
e[i]=(LL)i*d[i]%YL;
}
for(i=1;i<=n;++i){
if((x=i+(i&-i))>n)continue;
(d[x]+=d[i])%=YL;(e[x]+=e[i])%=YL;
}
while(m--)
switch(in()){
case 1:x=in();y=in();z=in()%YL;
for(;top[x]!=top[y];x=f[top[x]]){
if(dep[top[x]]<dep[top[y]])swap(x,y);
upd(id[top[x]],id[x]+1,z);
}
if(dep[x]<dep[y])swap(x,y);
upd(id[y],id[x]+1,z);
break;
case 2:x=in();y=in();ans=0;
for(;top[x]!=top[y];x=f[top[x]]){
if(dep[top[x]]<dep[top[y]])swap(x,y);
ans+=ask(id[top[x]]-1,id[x]);
}
if(dep[x]<dep[y])swap(x,y);
out((ans+ask(id[y]-1,id[x]))%YL);P('\n');
break;
case 3:x=in();z=in()%YL;
upd(id[x],id[x]+s[x],z);
break;
case 4:x=in();
out(ask(id[x]-1,id[x]+s[x]-1));P('\n');
}
fwrite(obuf,1,op-obuf,stdout);
return 0;
}

树剖模板(洛谷P3384 【模板】树链剖分)(树链剖分,树状数组,树的dfn序)的更多相关文章

  1. 树链剖分模板(洛谷P3384)

    洛谷P3384 #include <bits/stdc++.h> #define DBG(x) cerr << #x << " = " < ...

  2. [洛谷P3384] [模板] 树链剖分

    题目传送门 显然是一道模板题. 然而索引出现了错误,狂wa不止. 感谢神犇Dr_J指正.%%%orz. 建线段树的时候,第44行. 把sum[p]=bv[pos[l]]%mod;打成了sum[p]=b ...

  3. 洛谷 P3384 【模板】树链剖分-树链剖分(点权)(路径节点更新、路径求和、子树节点更新、子树求和)模板-备注结合一下以前写的题目,懒得写很详细的注释

    P3384 [模板]树链剖分 题目描述 如题,已知一棵包含N个结点的树(连通且无环),每个节点上包含一个数值,需要支持以下操作: 操作1: 格式: 1 x y z 表示将树从x到y结点最短路径上所有节 ...

  4. 洛谷p3384【模板】树链剖分题解

    洛谷p3384 [模板]树链剖分错误记录 首先感谢\(lfd\)在课上调了出来\(Orz\) \(1\).以后少写全局变量 \(2\).线段树递归的时候最好把左右区间一起传 \(3\).写\(dfs\ ...

  5. LCT总结——概念篇+洛谷P3690[模板]Link Cut Tree(动态树)(LCT,Splay)

    为了优化体验(其实是强迫症),蒟蒻把总结拆成了两篇,方便不同学习阶段的Dalao们切换. LCT总结--应用篇戳这里 概念.性质简述 首先介绍一下链剖分的概念(感谢laofu的讲课) 链剖分,是指一类 ...

  6. 洛谷P3373 [模板]线段树 2(区间增减.乘 区间求和)

    To 洛谷.3373 [模板]线段树2 题目描述 如题,已知一个数列,你需要进行下面两种操作: 1.将某区间每一个数加上x 2.将某区间每一个数乘上x 3.求出某区间每一个数的和 输入输出格式 输入格 ...

  7. 【数论】卢卡斯定理模板 洛谷P3807

    [数论]卢卡斯定理模板 洛谷P3807 >>>>题目 [题目] https://www.luogu.org/problemnew/show/P3807 [输入格式] 第一行一个 ...

  8. 洛谷 P4125 [WC2012]记忆中的水杉树【扫描线+set+线段树】

    我没有找到能在bzojAC的代码--当然我也WA了--但是我在洛谷过了,那就假装过了吧 minmax线段树一开始写的只能用min更新min,max更新max,实际上是可以互相更新的-- 首先看第二问, ...

  9. KMP字符串匹配 模板 洛谷 P3375

    KMP字符串匹配 模板 洛谷 P3375 题意 如题,给出两个字符串s1和s2,其中s2为s1的子串,求出s2在s1中所有出现的位置. 为了减少骗分的情况,接下来还要输出子串的前缀数组next.(如果 ...

  10. 【树链剖分】洛谷P3384树剖模板

    题目描述 如题,已知一棵包含N个结点的树(连通且无环),每个节点上包含一个数值,需要支持以下操作: 操作1: 格式: 1 x y z 表示将树从x到y结点最短路径上所有节点的值都加上z 操作2: 格式 ...

随机推荐

  1. Luogu4630 APIO2018 Duathlon 圆方树、树形DP

    传送门 要求的是一条按顺序经过\(s,t,c\)三个点的简单路径.简单路径的计数问题不难想到点双联通分量,进而使用圆方树进行求解. 首先将原图缩点,对于一个大小为\(size\)的点双联通分量内,在这 ...

  2. C# 异步上传图片案例

    好久没写博客了,都感觉自己快堕落了!今天随性写一篇关于异步上传图片的程序及插件! 说是程序及插件,其实程序占大头,所谓的插件只是两个JS.分别为:jquery.html5upload.js 和 jqu ...

  3. CF [2016-2017 ACM-ICPC CHINA-Final][GYM 101194 H] Great Cells

    很久以前做的一道思博题了,今天来补一补. 大致题意:在一个\(n*m\)的矩阵内填整数,数字在\([1,k]\)范围内.矩阵中某格的数为great number当且仅当与它同行同列的数字都严格比它小. ...

  4. 蓝牙 link timeout分析

    蓝牙主机和蓝牙设备建立连接之后,会在l2cap 层面上建立相应的channel,这些channel 基本上是用于各种不同的profile 或者protocol 进行通信用的. 当相应的profile或 ...

  5. 因写太多 BUG!程序员遭公司颁奖羞辱,做的一个比一个绝​

    刚入职的程序员新人,办公桌上,基本上也就一电脑.一键盘.一鼠标,再配个被杯子.然而混迹职场多年的猿老们,办公桌上都有一些彰显身份地位的“好东西”. 这张图两点颇多,最显眼的,是办公桌上那个黄黄的东西, ...

  6. WEB 小案例 -- 网上书城(四)

    针对于这个小案例我们今天讲解结账操作,也是有关这个案例的最后一次博文,说实话这个案例的博文写的很糟糕,不知道该如何去表述自己的思路,所以内容有点水,其实说到底还是功力不够. 处理思路 点击结账,发送结 ...

  7. ABP+AdminLTE+Bootstrap Table权限管理系统第十一节--Bootstrap Table用户管理列表以及Module Zero之用户管理

    返回总目录:ABP+AdminLTE+Bootstrap Table权限管理系统一期 用户实体 用户实体代表应用的一个用户,它派生自AbpUser类,如下所示: public class User : ...

  8. C# 爬虫 正则、NSoup、HtmlAgilityPack、Jumony四种方式抓取小说

    心血来潮,想爬点小说.通过百度选择了个小说网站,随便找了一本小说http://www.23us.so/files/article/html/13/13655/index.html. 1.分析html规 ...

  9. JSP页面<%@ ...%>是什么意思?

    这表示是指令,主要用来提供整个JSP 网页相关的信息,并且用来设定JSP网页的相关属性,例如:网页的编码方式.语法.信息等.起始符号为: <%@终止符号为: %>目前有三种指令:page. ...

  10. 使用Junit进行单元测试

    使用Junit进行单元测试 一.目的和要求 JUnit是一款由Erich Gamma(<设计模式>的作者)和Kent Beck(极限编程的提出者)编写的开源的回归测试框架,供Java编码人 ...