[CF161D]Distance in Tree-树状dp
Problem Distance in tree
题目大意
给出一棵树,求这棵树上有多少个最短距离为k的点对。
Solution
这个题目可以用点分治来做,然而我到现在还是没有学会点分治,所以只好用树形dp了。
这个题目,我们可以将其转化为一个个子树中搞事情,再慢慢合并。
设f[i][j]为以i为根的子树中距离根距离为j的点有多少个。
对于一个点u,我们枚举它的子节点v,则我们可以计算出经过u-v这条边的答案
我们枚举j=1->k,则ans+=f[u][j]*f[v][k-j-1];
枚举完以后,我们将这一棵子树合并到u节点去,以便统计u的其它子树。
具体过程我们只需要dfs一遍,对于每个叶子结点x,f[x][0]=1。
然后不断向上回溯,边回溯边进行如上计算,最后即可算出正确答案。
具体可以参考一下代码。
AC Code
#include <iostream>
#include <cstdio>
#include <cstring>
using namespace std;
struct node{
int to,next;
}e[];
int n,k,u,v,ans=,tot=;
int h[],f[][];
void add(int u,int v){
e[++tot].to=u;e[tot].next=h[v];h[v]=tot;
e[++tot].to=v;e[tot].next=h[u];h[u]=tot;
}
void dfs(int x,int last){
f[x][]=;
for(int i=h[x];~i;i=e[i].next){
if(e[i].to!=last){
dfs(e[i].to,x);
for(int j=;j<k;j++)ans+=f[x][j]*f[e[i].to][k-j-];
for(int j=;j<=k;j++)f[x][j]+=f[e[i].to][j-];
}
}
}
int main(){
// freopen("cf161d.in","r",stdin);
memset(h,-,sizeof(h));
scanf("%d%d",&n,&k);
for(int i=;i<n;i++){
scanf("%d%d",&u,&v);
add(u,v);
}
dfs(,);
printf("%d",ans);
}

1 #include <iostream>
2 #include <cstdio>
3 #include <cstring>
4 using namespace std;
5 struct node{
6 int next,to;
7 }e[200010];
8 bool neko[100010];
9 int n,m,d,x,u,v,path[100010],h[100010],ans=0,tot=0;
10 int pathp[100010],pathn[100010];
11 void add(int u,int v){
12 e[++tot].to=u;e[tot].next=h[v];h[v]=tot;
13 e[++tot].to=v;e[tot].next=h[u];h[u]=tot;
14 }
15 void dfspath(int x,int last){
16 path[x]=-2333333;pathp[x]=-2333333;
17 for(int i=h[x];~i;i=e[i].next){
18 if(e[i].to!=last){
19 dfspath(e[i].to,x);
20 if(path[x]<path[e[i].to]+1){
21 pathp[x]=path[x];
22 path[x]=path[e[i].to]+1;
23 pathn[x]=e[i].to;
24 }else if(pathp[x]<path[e[i].to]+1)pathp[x]=path[e[i].to]+1;
25 }
26 }
27 if(neko[x]&&path[x]<-2000000)path[x]=0;
28 if(neko[x]&&pathp[x]<-2000000)pathp[x]=0;
29 }
30 void dpdfs(int x,int last){
31 if(~last)
32 if(pathn[last]==x){
33 if(pathp[last]+1>path[x]){
34 pathp[x]=path[x];
35 path[x]=pathp[last]+1;
36 pathn[x]=0;
37 }else if(pathp[last]+1>pathp[x])pathp[x]=pathp[last]+1;
38 }else{
39 if(path[last]+1>path[x]){
40 pathp[x]=path[x];
41 path[x]=path[last]+1;
42 pathn[x]=0;
43 }else if(path[last]+1>pathp[x])
44 pathp[x]=path[last]+1;
45 }
46 if(path[x]<=d)ans++;
47 for(int i=h[x];~i;i=e[i].next)
48 if(e[i].to!=last)dpdfs(e[i].to,x);
49 }
50 int main(){
51 // freopen("cf337d.in","r",stdin);
52 memset(h,-1,sizeof(h));
53 scanf("%d%d%d",&n,&m,&d);
54 for(int i=1;i<=m;i++)
55 scanf("%d",&x),neko[x]=1;
56 for(int i=1;i<n;i++){
57 scanf("%d%d",&u,&v);
58 add(u,v);
59 }
60 dfspath(1,1);
61 dpdfs(1,-1);
62 printf("%d",ans);
63 }

[CF161D]Distance in Tree-树状dp的更多相关文章
- poj2486--Apple Tree(树状dp)
Apple Tree Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 7789 Accepted: 2606 Descri ...
- Codeforces 161D Distance in Tree(树型DP)
题目链接 Distance in Tree $k <= 500$ 这个条件十分重要. 设$f[i][j]$为以$i$为子树,所有后代中相对深度为$j$的结点个数. 状态转移的时候,一个结点的信息 ...
- POJ 2486 Apple Tree [树状DP]
题目:一棵树,每个结点上都有一些苹果,且相邻两个结点间的距离为1.一个人从根节点(编号为1)开始走,一共可以走k步,问最多可以吃多少苹果. 思路:这里给出数组的定义: dp[0][x][j] 为从结点 ...
- CodeForces 160D - Distance in Tree 树型DP
题目给了512MB的空间....用dp[k][i]代表以k为起点...往下面走(走直的不打岔)i步能有多少方案....在更新dp[k][i]过程中同时统计答案.. Program: #include& ...
- Codeforces 461B - Appleman and Tree 树状DP
一棵树上有K个黑色节点,剩余节点都为白色,将其划分成K个子树,使得每棵树上都仅仅有1个黑色节点,共同拥有多少种划分方案. 个人感觉这题比較难. 如果dp(i,0..1)代表的是以i为根节点的子树种有0 ...
- D. Distance in Tree(树型Dp计数)
\(其实思路都能想到一点,就是去重这里特别麻烦,没有好的思路.\) \(设dp[i][j]为以i为根深度为j的节点数量\) \(dp[parent][j]=\sum{dp[son][j-1]}\) \ ...
- HDU 4714 Tree2cycle(树状DP)(2013 ACM/ICPC Asia Regional Online ―― Warmup)
Description A tree with N nodes and N-1 edges is given. To connect or disconnect one edge, we need 1 ...
- 树状DP (poj 2342)
题目:Anniversary party 题意:给出N各节点的快乐指数,以及父子关系,求最大快乐指数和(没人职员愿意跟直接上司一起玩): 思路:从底向上的树状DP: 第一种情况:第i个员工不参与,F[ ...
- poj3659树状DP
Cell Phone Network Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 6273 Accepted: 225 ...
- hdu 1561 The more, The Better_树状dp
题目链接 题意:给你一棵树,各个节点都有价值(除根节点),从根节点出发,选择m个节点,问最多的价值是多小. 思路:很明显是树状dp,遍历树时背包最优价值,dp[i][k]=max{dp[i][r]+d ...
随机推荐
- Apache许可翻译
https://www.apache.org/licenses/LICENSE-2.0 Apache许可 2.0 2004.1 使用.复制和发行的术语和条件. 1 定义 "License&q ...
- angular实现的文字上下无缝滚动
最近在学习angularJs,业余时间随便写了一个文字上下无缝滚动的例子,主要写了一个小小的指令. css代码:主要控制样式 <style type="text/css"&g ...
- 用NIO实现http协议
先来看一下本篇博文的目录: 一:简介Nio 二:Nio的好处 三:关于http协议 四:代码实现 五:总结 一:简介Nio 我们都知道io流,那么NIO是什么呢?本篇博文将会带你一探NIO,NIO的全 ...
- [深圳/广州]微软SQL技术沙龙分享会(MVP)
[深圳/广州] 新一期俱乐部活动报名开始,这次是广深地区SQL Server 技术沙龙分享会(MVP),SQL Server作为一个数据平台,不管是SQL Server 2017 on Linux 还 ...
- 网络编程应用:基于TCP协议【实现文件上传】--练习
要求: 基于TCP协议实现一个向服务器端上传文件的功能 客户端代码: package Homework2; import java.io.File; import java.io.FileInputS ...
- [python标准库]Pickle模块
Pickle-------python对象序列化 本文主要阐述以下几点: 1.pickle模块简介 2.pickle模块提供的方法 3.注意事项 4.实例解析 1.pickle模块简介 The pic ...
- 刨根究底字符编码之十二——UTF-8究竟是怎么编码的
UTF-8究竟是怎么编码的 1. UTF-8编码是Unicode字符集的一种编码方式(CEF),其特点是使用变长字节数(即变长码元序列.变宽码元序列)来编码.一般是1到4个字节,当然,也可以更长. 为 ...
- charles抓包,打断点,连接手机抓包
写给我自己: 如果是使用charles抓包.一定要tm的保证手机和电脑连的是一个网. charles抓本地包的操作 1.打开charles, 2.打开浏览器访问某网页,就可抓到对应的包 charles ...
- 初识Tensorboard
1.什么是Tensorboard? PPT设计原则中有这样一条,叫"文不如表,表不如图",可见图表在表达中更为直观.明确.程序设计中也是一样,我们经常用图表来描述程序的结构和流程, ...
- Chapter2:Discrete-Time Signal Processing and Short-Time Fourier Analysis
作者:桂. 时间:2017-05-24 08:44:53 主要是<Speech enhancement: theory and practice>的读书笔记,全部内容可以点击这里. 这一 ...

