[luogu3258][JLOI2014]松鼠的新家
题解
我们就在\([a_i,a_{i+1}]\)的路径上都\(+1\),然后单点查询就可以了。
ac代码(吸了氧才过的QwQ)
# include <bits/stdc++.h>
# define LL long long
# define ms(a,b) memset(a,b,sizeof(a))
# define ri (register int)
# define inf (0x7f7f7f7f)
# define pb push_back
# define fi first
# define se second
# define pii pair<int,int>
# define File(s) freopen(s".in","r",stdin),freopen(s".out","w",stdout)
using namespace std;
inline int gi(){
int w=0,x=0;char ch=0;
while(!isdigit(ch)) w|=ch=='-',ch=getchar();
while(isdigit(ch)) x=(x<<1)+(x<<3)+(ch^48),ch=getchar();
return w?-x:x;
}
# define N 1300005
struct segment_tree{
# define mid ((l+r)>>1)
# define ls (nod<<1)
# define rs (nod<<1|1)
struct node{
int l,r,s,tag;
}tr[N<<2];
void pushup(int nod){
tr[nod].s=tr[ls].s+tr[rs].s;
}
void pushdown(int nod){
register int tmp=tr[nod].tag,l=tr[nod].l,r=tr[nod].r; tr[nod].tag=0;
if (tmp==0) return;
tr[ls].tag+=tmp; tr[rs].tag+=tmp;
tr[ls].s+=tmp*(mid-l+1); tr[rs].s+=tmp*(r-mid);
}
void build(int l,int r,int nod){
tr[nod].l=l,tr[nod].r=r,tr[nod].tag=0,tr[nod].s=0;
if (l==r) return;
build(l,mid,ls); build(mid+1,r,rs);
pushup(nod);
}
void update_sec(int nod,int ql,int qr,int v){
register int l=tr[nod].l,r=tr[nod].r; pushdown(nod);
if (ql<=l&&r<=qr){
tr[nod].tag+=v;
tr[nod].s+=(r-l+1)*v;
return;
}
if (ql<=mid) update_sec(ls,ql,qr,v);
if (qr>mid) update_sec(rs,ql,qr,v);
pushup(nod);
}
int query_point(int nod,int k){
register int l=tr[nod].l,r=tr[nod].r;
pushdown(nod);
if (l>=r) return tr[nod].s;
if (k<=mid) return query_point(ls,k);
else return query_point(rs,k);
}
}tr;
struct edge{
int to,nt;
}E[N<<1];
int son[N],top[N],sz[N],fa[N],H[N],dep[N],idx[N],a[N];
int cnt,tot,n,m;
inline void addedge(int u,int v){
E[++cnt]=(edge){v,H[u]}; H[u]=cnt;
}
inline void dfs1(int u,int ft,int dp){
dep[u]=dp; fa[u]=ft; sz[u]=1;
register int maxson=-1;
for (register int e=H[u];e;e=E[e].nt){
int v=E[e].to; if (v==fa[u]) continue;
dfs1(v,u,dp+1); sz[u]+=sz[v];
if (sz[v]>maxson) maxson=sz[v],son[u]=v;
}
}
inline void dfs2(int u,int tp){
top[u]=tp; idx[u]=++tot;
if (!son[u]) return;
dfs2(son[u],tp);
for (register int e=H[u];e;e=E[e].nt){
int v=E[e].to; if (v==fa[u]||v==son[u]) continue;
dfs2(v,v);
}
}
void update(int u,int v,int w){
while (top[u]!=top[v]){
if (dep[top[u]]<dep[top[v]]) swap(u,v);
tr.update_sec(1,idx[top[u]],idx[u],w);
u=fa[top[u]];
}
if (dep[u]>dep[v]) swap(u,v);
tr.update_sec(1,idx[u],idx[v],w);
}
int main(){
n=gi();
for (int i=1;i<=n;++i) a[i]=gi();
for (int i=1;i<n;++i){
int u=gi(),v=gi();
addedge(u,v); addedge(v,u);
}
dfs1(1,0,1); dfs2(1,1); tr.build(1,n,1);
for (int i=1;i<n;++i){
update(a[i],a[i+1],1);
update(a[i+1],a[i+1],-1);
}
for (int i=1;i<=n;++i) printf("%d\n",tr.query_point(1,idx[i]));
return 0;
}
[luogu3258][JLOI2014]松鼠的新家的更多相关文章
- BZOJ 3631: [JLOI2014]松鼠的新家( 树链剖分 )
裸树链剖分... ------------------------------------------------------------------- #include<bits/stdc++ ...
- 3631: [JLOI2014]松鼠的新家
3631: [JLOI2014]松鼠的新家 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 707 Solved: 342[Submit][Statu ...
- [填坑]树上差分 例题:[JLOI2014]松鼠的新家(LCA)
今天算是把LCA这个坑填上了一点点,又复习(其实是预习)了一下树上差分.其实普通的差分我还是会的,树上的嘛,也是懂原理的就是没怎么打过. 我们先来把树上差分能做到的看一下: 1.找所有路径公共覆盖的边 ...
- P3258 [JLOI2014]松鼠的新家
P3258 [JLOI2014]松鼠的新家倍增lca+树上差分,从叶子节点向根节点求前缀和,dfs求子树和即可,最后,把每次的起点和终点都. #include<iostream> #inc ...
- 洛谷 P3258 [JLOI2014]松鼠的新家 解题报告
P3258 [JLOI2014]松鼠的新家 题目描述 松鼠的新家是一棵树,前几天刚刚装修了新家,新家有n个房间,并且有n-1根树枝连接,每个房间都可以相互到达,且俩个房间之间的路线都是唯一的.天哪,他 ...
- 【洛谷】【lca+树上差分】P3258 [JLOI2014]松鼠的新家
[题目描述:] 松鼠的新家是一棵树,前几天刚刚装修了新家,新家有n(2 ≤ n ≤ 300000)个房间,并且有n-1根树枝连接,每个房间都可以相互到达,且俩个房间之间的路线都是唯一的.天哪,他居然真 ...
- [Luogu 3258] JLOI2014 松鼠的新家
[Luogu 3258] JLOI2014 松鼠的新家 LCA + 树上差分. 我呢,因为是树剖求的 LCA,预处理了 DFN(DFS 序),于是简化成了序列差分. qwq不讲了不讲了,贴代码. #i ...
- [JLOI2014] 松鼠的新家 (lca/树上差分)
[JLOI2014]松鼠的新家 题目描述 松鼠的新家是一棵树,前几天刚刚装修了新家,新家有n个房间,并且有n-1根树枝连接,每个房间都可以相互到达,且俩个房间之间的路线都是唯一的.天哪,他居然真的住在 ...
- 洛谷P3258 [JLOI2014]松鼠的新家
P3258 [JLOI2014]松鼠的新家 题目描述 松鼠的新家是一棵树,前几天刚刚装修了新家,新家有n个房间,并且有n-1根树枝连接,每个房间都可以相互到达,且俩个房间之间的路线都是唯一的.天哪,他 ...
随机推荐
- AT3611 Tree MST
题面 题解 考虑最小化\(dis(x, y)\) 这里需要对一种奇怪的最小生成树算法:Boruvka算法有深刻的理解. 考虑该算法的执行过程,我们可以考虑进行点分治,每次找到离分治重心最近的点,然后将 ...
- springmvc 解决 controller 中出现死循环并 stackoverflow 的问题
这是因为这个controller中的方法返回值为void类型,且没有request response这类衍生的重定向,或者返回值为String,但是是null等等的情况,都会引起死循环,然后stack ...
- 基于 HTML5 Canvas 的 3D WebGL 机房创建
对于 3D 机房来说,监控已经不是什么难事,不同的人有不同的做法,今天试着用 HT 写了一个基于 HTML5 的机房,发现果然 HT 简单好用.本例是将灯光.雾化以及 eye 的最大最小距离等等功能在 ...
- 免费的 Vue.js 入门与进阶视频教程
这是我免费发布的高质量超清「Vue.js 入门与进阶视频教程」. 全网最好的.免费的 Vue.js 视频教程,课程基于 Vue.js 2.0,由浅入深,最后结合实际的项目进行了最棒的技术点讲解,此课程 ...
- 牛客网-小白月赛6-J-洋灰三角
题目链接https://www.nowcoder.com/acm/contest/136/J 这题我还是不找规律了,老老实实推吧,传说找规律也可以,我还是算了 递推式:f(n)=k*f(n-1)+p ...
- .apply()用法和call()的区别
Js apply方法详解我在一开始看到javascript的函数apply和call时,非常的模糊,看也看不懂,最近在网上看到一些文章对apply方法和call的一些示例,总算是看的有点眉目了,在这里 ...
- 《Linux内核设计与实现》 第三章学习笔记
一.进程 1.进程就是处于执行期的程序(目标码存放在某种存储介质上).但进程并不仅仅局限于一段可执行程序代码,通常进程还要包含其他资源.执行线程,简称线程(thread),是在进程中活动的对象. 2. ...
- linux内核设计第七周——可执行程序的装载
- <<架构漫谈>>读后感
今天按照老师的要求,看了架构漫谈1--9讲,觉得受益良多,以下是我得点点读后感: (一)什么是架构? 架构的英文是Architecture,从定义上看,架构好像是一个过程,也不是很清晰.下面从架构的缘 ...
- Sprint 冲刺第三阶段第一天
1.今晚我在整理之前的代码,检查细节,然后发现游戏要返回上一界面竟然出现了问题“项目停止运行”,仔细检查没办法解决,后来百度可能是因为修改了之前文件的名字,可在AndroidManifest.xml中 ...