bzoj3631 [JLOI2014]松鼠的新家——树上差分

时间:2022-09-01 15:53:56

题目:https://www.lydsy.com/JudgeOnline/problem.php?id=3631

树上差分;注意路径的结尾被多算了一次,最后要减去(不能提前减)。

代码如下:

#include<iostream>
#include<cstdio>
#include<cstring>
using namespace std;
int const maxn=;
int n,a[maxn],head[maxn],ct,f[maxn],re[maxn],fa[maxn][],bin[],deep[maxn];
struct N{
int to,next;
N(int t=,int n=):to(t),next(n) {}
}edge[maxn<<];
bool vis[maxn];
void dfs(int x)
{
for(int i=;i<=;i++)
{
if(deep[x]>=bin[i])fa[x][i]=fa[fa[x][i-]][i-];
else break;
}
for(int i=head[x],u;i;i=edge[i].next)
{
if(edge[i].to==fa[x][])continue;
deep[u=edge[i].to]=deep[x]+;
fa[u][]=x;
dfs(u);
}
}
int lca(int x,int y)
{
if(deep[x]>deep[y])swap(x,y);
int t=deep[y]-deep[x];
for(int i=;i<=;i++)
if(t&bin[i])y=fa[y][i];
for(int i=;i>=;i--)
if(fa[x][i]!=fa[y][i])
x=fa[x][i],y=fa[y][i];
if(x==y)return y;
return fa[y][];
}
void dfs2(int x)
{
// cout<<x<<endl;
if(vis[x])return;
vis[x]=;
for(int i=head[x],u;i;i=edge[i].next)
{
u=edge[i].to;
if(u==fa[x][])continue;
dfs2(u);
f[x]+=f[u];
}
}
int main()
{
bin[]=;
for(int i=;i<;i++)bin[i]=(bin[i-]<<);
scanf("%d",&n);
for(int i=;i<=n;i++)scanf("%d",&a[i]);
for(int i=,x,y;i<n;i++)
{
scanf("%d%d",&x,&y);
edge[++ct]=N(y,head[x]);head[x]=ct;
edge[++ct]=N(x,head[y]);head[y]=ct;
}
dfs();
for(int i=;i<=n;i++)
{
f[a[i-]]++;f[a[i]]++;re[a[i]]++;
int l=lca(a[i-],a[i]);
f[l]--;f[fa[l][]]--;
}
dfs2();
for(int i=;i<=n;i++)
printf("%d\n",f[i]-re[i]);
return ;
}

bzoj3631 [JLOI2014]松鼠的新家——树上差分的更多相关文章

  1. BZOJ 3631&colon; &lbrack;JLOI2014&rsqb;松鼠的新家 树上差分 &plus; LCA

    Description 松鼠的新家是一棵树,前几天刚刚装修了新家,新家有n个房间,并且有n-1根树枝连接,每个房间都可以相互到达,且俩个房间之间的路线都是唯一的.天哪,他居然真的住在“树”上.松鼠想邀 ...

  2. &lbrack;JLOI2014&rsqb;松鼠的新家 树上差分

    差分 一开始竟然想分情况讨论来差分,然后发现各自情况要分析, 就是为了解决中间节点重复计算的问题, 结果 最后一想,中间重复计算了一次,那我最后减掉不就好了么,,, 那这就是一道差分裸题了(这是唯一不 ...

  3. BZOJ&period;3631&period;&lbrack;JLOI2014&rsqb;松鼠的新家&lpar;树上差分&rpar;

    题目链接 树剖/差分裸题.. //28260kb 584ms #include <cstdio> #include <cctype> #include <algorith ...

  4. &lbrack;Bzoj3631&rsqb;&lbrack;JLOI2014&rsqb;松鼠的新家 (树上前缀和)

    3631: [JLOI2014]松鼠的新家 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 2350  Solved: 1212[Submit][Sta ...

  5. BZOJ3631 &lbrack;JLOI2014&rsqb;松鼠的新家 【树上差分】

    题目 松鼠的新家是一棵树,前几天刚刚装修了新家,新家有n个房间,并且有n-1根树枝连接,每个房间都可以相互到达,且俩个房间之间的路线都是唯一的.天哪,他居然真的住在"树"上.松鼠想 ...

  6. &lbrack;BZOJ3631&rsqb;&colon;&lbrack;JLOI2014&rsqb;松鼠的新家(LCA&plus;树上差分)

    题目传送门 题目描述: 松鼠的新家是一棵树,前几天刚刚装修了新家,新家有n个房间,并且有n-1根树枝连接,每个房间都可以相互到达,且俩个房间之间的路线都是唯一的.天哪,他居然真的住在“树”上.松鼠想邀 ...

  7. 【bzoj3631】&lbrack;JLOI2014&rsqb;松鼠的新家 LCA&plus;差分数组

    题目描述 松鼠的新家是一棵树,前几天刚刚装修了新家,新家有n个房间,并且有n-1根树枝连接,每个房间都可以相互到达,且俩个房间之间的路线都是唯一的.天哪,他居然真的住在“树”上.松鼠想邀请小熊维尼前来 ...

  8. bzoj3631&lbrack;JLOI2014 松鼠的新家 倍增lca&plus;差分

    裸的树上差分+倍增lca 每次从起点到终点左闭右开,这就有一个小技巧,要找到右端点向左端点走的第一步,然后差分就好了 #include<cstdio> #include<cstrin ...

  9. BZOJ 3631 松鼠的新家 树上差分

    我猜会有智障说直接链剖+线段树…(希望没有) From RYC's 课件 然鹅我并不反对树剖...我是智障...QAQ 好吧还是树上差分:设 a[i]=u.a[i+1]=v ++w[u],++w[v] ...

随机推荐

  1. Linux 信号量详解一

    信号量主要用于进程间(不是线程)的互斥,通过sem_p()函数加锁使用资源,sem_v函数解锁释放资源,在加锁期间,CPU从硬件级别关闭中断,防止pv操作被打断. semget函数 int semge ...

  2. javamail 发送附件

    1.属性文件 mail.protocol=smtpmail.host=mail.port=mail.auth=truemail.timeout=25000mail.username=mail.pass ...

  3. 【Java每日一题】20161110

    package Nov2016; import java.util.HashSet; public class Ques1110 { public static void main(String[] ...

  4. Android 开发问题集合

    1.屏幕横.竖切换 修改“AndroidManifest.xml”的android:screenOrientation 一般需要:landscape.portrait 2.修改应用名字 修改“Andr ...

  5. Java生成word文档

    itext-rtf-2.1.7.jar,下载地址:http://download.csdn.net/detail/xuxu198899223/7717727 itext-2.1.7.jar 下载地址: ...

  6. Spring AOP术语解释

    话说,越来越感觉有些人解释概念真的是晦涩难懂,我刚开始学习Spring aop时,对那些切入点,连接点,引入等概念搞得头疼.太多人就直接照搬定义,让我们这些初学者如何理解啊.下面是我找了大量的博客,终 ...

  7. HDU1541--Stars(树状数组)

    Stars Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) Total Subm ...

  8. Redis的两种持久化方式-快照持久化和AOF持久化

    Redis为了内部数据的安全考虑,会把本身的数据以文件形式保存到硬盘中一份,在服务器重启之后会自动把硬盘的数据恢复到内存(redis)的里边,数据保存到硬盘的过程就称为"持久化"效 ...

  9. token登录验证机制图解

  10. 读《分布式一致性原理》JAVA客户端API操作2

    创建节点 通过客户端API来创建一个数据节点,有一下两个接口: public String create(final String path, byte data[], List<ACL> ...