CF337D Book of Evil - 树型dp

题目大意:
一棵树上有一个特殊点,特殊点可以影响距离小于等于d的点,现在告诉被影响的点,问特殊点可以在几个点上。
题目分析:
对题意进行转化:求到被影响点的最大距离小于等于d的点数目。
然后就可以进行树型dp,求最大距离需要进行两次dp,第一次子树向父节点传递有用信息,第二字父节点向子树传递有用信息。dp[u][1]表示u距离以该节点为根的子树中的被影响点的最大距离,dp[u][0]表示u距离该子树外的被影响点的最大距离。
\]
\]
其中第二次中的max{dp[u][1} + 2)如果正是从v转移来的,就取次大值。
初始化如果该节点就是被影响的点那么距离为0,否则为-1。注意当dp之中出现了-1时要进行各种特判。
code
#include<bits/stdc++.h>
using namespace std;
const int N = 1e5 + 5;
int n, m, d, dp[N][2], ans;
bool mark[N];
vector<int> adj[N];
inline void dfs1(int u, int f){
int maxDisDown = -1;
dp[u][1] = mark[u] ? 0 : -1;
for(int i = adj[u].size()-1; i >= 0; i--){
int v = adj[u][i];
if(v == f) continue;
dfs1(v, u);
maxDisDown = max(maxDisDown, dp[v][1]);
}
if(maxDisDown != -1)
dp[u][1] = max(dp[u][1], maxDisDown + 1);
}
inline void dfs2(int u, int f){
int mx1 = -1, mx2 = -1;
for(int i = adj[u].size()-1; i >= 0; i--){
int v = adj[u][i];
if(v == f) continue;
if(dp[v][1] > mx1){
mx2 = mx1;
mx1 = dp[v][1];
}
else if(dp[v][1] > mx2){
mx2 = dp[v][1];
}
}
for(int i = adj[u].size()-1; i >= 0; i--){
int v = adj[u][i];
if(v == f) continue;
int siblingDis = dp[v][1] == mx1 ? mx2 : mx1;
if(siblingDis != -1)
siblingDis += 2;
dp[v][0] = siblingDis;
if(dp[u][0] != -1)
dp[v][0] = max(dp[v][0], dp[u][0] + 1);
if(mark[v])
dp[v][0] = max(dp[v][0], 0);
dfs2(v, u);
}
}
int main(){
// freopen("h.in", "r", stdin);
scanf("%d%d%d", &n, &m, &d);
for(int i = 1; i <= m; i++){
int x; scanf("%d", &x);
mark[x] = true;
}
for(int i = 1; i < n; i++){
int x, y; scanf("%d%d", &x, &y);
adj[x].push_back(y), adj[y].push_back(x);
}
dfs1(1, 0);
dp[1][0] = mark[1] ? 0 : -1;
dfs2(1, 0);
for(int i = 1; i <= n; i++)
ans += dp[i][0] <= d && dp[i][1] <= d ? 1 : 0;
printf("%d", ans);
return 0;
}
CF337D Book of Evil - 树型dp的更多相关文章
- POJ3659 Cell Phone Network(树上最小支配集:树型DP)
题目求一棵树的最小支配数. 支配集,即把图的点分成两个集合,所有非支配集内的点都和支配集内的某一点相邻. 听说即使是二分图,最小支配集的求解也是还没多项式算法的.而树上求最小支配集树型DP就OK了. ...
- POJ 3342 - Party at Hali-Bula 树型DP+最优解唯一性判断
好久没写树型dp了...以前都是先找到叶子节点.用队列维护来做的...这次学着vector动态数组+DFS回朔的方法..感觉思路更加的清晰... 关于题目的第一问...能邀请到的最多人数..so ea ...
- 【XSY1905】【XSY2761】新访问计划 二分 树型DP
题目描述 给你一棵树,你要从\(1\)号点出发,经过这棵树的每条边至少一次,最后回到\(1\)号点,经过一条边要花费\(w_i\)的时间. 你还可以乘车,从一个点取另一个点,需要花费\(c\)的时间. ...
- 洛谷P3354 Riv河流 [IOI2005] 树型dp
正解:树型dp 解题报告: 传送门! 简要题意:有棵树,每个节点有个权值w,要求选k个节点,最大化∑dis*w,其中如果某个节点到根的路径上选了别的节点,dis指的是到达那个节点的距离 首先这个一看就 ...
- 【POJ 3140】 Contestants Division(树型dp)
id=3140">[POJ 3140] Contestants Division(树型dp) Time Limit: 2000MS Memory Limit: 65536K Tot ...
- Codeforces 581F Zublicanes and Mumocrates(树型DP)
题目链接 Round 322 Problem F 题意 给定一棵树,保证叶子结点个数为$2$(也就是度数为$1$的结点),现在要把所有的点染色(黑或白) 要求一半叶子结点的颜色为白,一半叶子结点的 ...
- ZOJ 3949 (17th 浙大校赛 B题,树型DP)
题目链接 The 17th Zhejiang University Programming Contest Problem B 题意 给定一棵树,现在要加一条连接$1$(根结点)和$x$的边,求加 ...
- BZOJ 1564 :[NOI2009]二叉查找树(树型DP)
二叉查找树 [题目描述] 已知一棵特殊的二叉查找树.根据定义,该二叉查找树中每个结点的数据值都比它左儿子结点的数据值大,而比它右儿子结点的数据值小. 另一方面,这棵查找树中每个结点都有一个权值,每个结 ...
- Codeforces 149D Coloring Brackets(树型DP)
题目链接 Coloring Brackets 考虑树型DP.(我参考了Q巨的代码还是略不理解……) 首先在序列的最外面加一对括号.预处理出DFS树. 每个点有9中状态.假设0位不涂色,1为涂红色,2为 ...
随机推荐
- Python产生随机数组,测试用
import numpy as np if __name__ == '__main__': a=np.random.randint(0,10,size=[3,3]) print(a) 输出: [ ...
- JVM route
http://www.linuxidc.com/Linux/2013-06/86446.htm
- HTML、XHTML、css速记
一.HTML 下面内容记录经常使用的html元素.可另存为html文件以查看效果: <!doctype html> <html lang="zh-cn"> ...
- Nginx TCP代理
nginx 在1.9.0 版本发布以前如果要想做到基于TCP的代理及负载均衡需要通过打名为nginx_tcp_proxy_module的第三方patch来实现,该模块的代码托管在github上 网址: ...
- 【习题 3-9 UVA - 10340】All in All
[链接] 我是链接,点我呀:) [题意] 在这里输入题意 [题解] 相当于让你判断s1是不是s2的子序列. for一遍就好 [代码] #include <bits/stdc++.h> us ...
- 缓存(cache)的理解
缓存的特点: 读取速度很快,容量相比硬盘较小: 缓存在实现时,本质上仍然是一块内存区域: cache 机制的一个核心关注点还在于,究竟什么样的数据应该放在缓存中,显然不是所有,那就应当是部分,就应该是 ...
- ITFriend开发日志20140611
原文链接:http://www.itfriend.cn/user/ITFriend/article/details/100274 1.调整登录页. 把大背景图,改为通用的banner图,节省流量. 登 ...
- Xvisor ARM32 启动分析
Linux内核历史悠久,特性丰富,但是代码量庞大,各个子系统交叉繁琐.对于想要将操作系统内核各个特性研究一遍的人,有时候也只好"望Linux兴叹".Xvisor是一个较新的Type ...
- 30、在LCD上显示摄像头图像
1. 准备虚拟机2.安装工具链sudo tar xjf arm-linux-gcc-4.3.2.tar.bz2 -C /设置环境变量:sudo vi /etc/environment : PATH=& ...
- 在vue中使用babel-polyfill
在 Vue.js项目中使用Vuex,Vuex 依赖 Promise,所以如果你的浏览器没有实现 Promise (比如 IE),那么就需要使用一个 polyfill 的库 我们可以通过babel-pr ...