洛谷 P3267 [JLOI2016/SHOI2016]侦察守卫(树形dp)
题面
题解
树形\(dp\)
\(f[x][y]表示x的y层以下的所有点都已经覆盖完,还需要覆盖上面的y层的最小代价。\)
\(g[x][y]表示x子树中所有点都已经覆盖完,并且x还能向上覆盖y层的最小代价。\)
对于 \(u->v\), \(u\)为\(v\)的父亲:
\(g[u][j] = min(g[u][j]+f[v][j], g[v][j+1]+f[u][j+1])\)
\(f[u][j] = Σf[v][j-1]\)
\(g[u][j] = min(g[u][j], g[u][j+1])\)
\(f[u][j] = min(f[u][j], f[u][j-1])\)
Code
#include<bits/stdc++.h>
#define LL long long
#define RG register
using namespace std;
template<class T> inline void read(T &x) {
    x = 0; RG char c = getchar(); bool f = 0;
    while (c != '-' && (c < '0' || c > '9')) c = getchar(); if (c == '-') c = getchar(), f = 1;
    while (c >= '0' && c <= '9') x = x*10+c-48, c = getchar();
    x = f ? -x : x;
    return ;
}
template<class T> inline void write(T x) {
    if (!x) {putchar(48);return ;}
    if (x < 0) x = -x, putchar('-');
    int len = -1, z[20]; while (x > 0) z[++len] = x%10, x /= 10;
    for (RG int i = len; i >= 0; i--) putchar(z[i]+48);return ;
}
const int N = 500010, INF = 1e9;
int n, d, w[N];
struct node {
    int to, next;
}G[N<<1];
int last[N], gl;
bool vis[N];
void add(int x, int y) {
    G[++gl] = (node) {y, last[x]};
    last[x] = gl;
}
int f[N][22], g[N][22];
void dfs(int u, int fa) {
    if (vis[u]) f[u][0] = g[u][0] = w[u];
    for (int i = 1; i <= d; i++) g[u][i] = w[u];
    g[u][d+1] = INF;
    for (int i = last[u]; i; i = G[i].next) {
        int v = G[i].to;
        if (v == fa) continue;
        dfs(v, u);
    }
    for (int i = last[u]; i; i = G[i].next) {
        int v = G[i].to;
        if (v == fa) continue;
        for (int j = 0; j <= d; j++) g[u][j] = min(g[u][j]+f[v][j], f[u][j+1]+g[v][j+1]);
        for (int j = d; j >= 0; j--) g[u][j] = min(g[u][j], g[u][j+1]);
        f[u][0] = g[u][0];
        for (int j = 1; j <= d; j++) f[u][j] += f[v][j-1];
        for (int j = 1; j <= d; j++) f[u][j] = min(f[u][j], f[u][j-1]);
    }
    return ;
}
int main() {
    read(n); read(d);
    for (int i = 1; i <= n; i++) read(w[i]);
    int m; read(m);
    for (int i = 1; i <= m; i++) {
        int x; read(x);
        vis[x] = 1;
    }
    for (int i = 1; i < n; i++) {
        int x, y; read(x); read(y);
        add(x, y); add(y, x);
    }
    dfs(1, 0);
    printf("%d\n", g[1][0]);
    return 0;
}
洛谷 P3267 [JLOI2016/SHOI2016]侦察守卫(树形dp)的更多相关文章
- 洛谷 P3267 - [JLOI2016/SHOI2016]侦察守卫(树形 dp)
		洛谷题面传送门 经典题一道,下次就称这种"覆盖距离不超过 xxx 的树形 dp"为<侦察守卫模型> 我们考虑树形 \(dp\),设 \(f_{x,j}\) 表示钦定了 ... 
- 洛谷 P3177 [HAOI2015]树上染色 树形DP
		洛谷 P3177 [HAOI2015]树上染色 树形DP 题目描述 有一棵点数为 \(n\) 的树,树边有边权.给你一个在 \(0 \sim n\)之内的正整数 \(k\) ,你要在这棵树中选择 \( ... 
- 洛谷P1040 加分二叉树(树形dp)
		加分二叉树 时间限制: 1 Sec 内存限制: 125 MB提交: 11 解决: 7 题目描述 设一个n个节点的二叉树tree的中序遍历为(l,2,3,...,n),其中数字1,2,3,...,n ... 
- 洛谷P4438 道路 [HNOI/AHOI2018] 树形dp
		正解:树形dp 解题报告: 传送门! 昂首先看懂题目趴QwQ大概就是说有棵满二叉树,有n个叶子节点(乡村)和n-1个非叶子节点,然后这棵树的每个节点有三个属性abc,对每个非叶子节点可以从与子节点的两 ... 
- 洛谷 P4201 设计路线 [NOI2008] 树形dp
		正解:树形dp 解题报告: 大概是第一道NOI的题目?有点激动嘻嘻 然后先放个传送门 先大概港下这题的题意是啥qwq 大概就是给一棵树,然后可以选若干条链把链上的所有边的边权变成0,但是这些链不能有交 ... 
- P3267 [JLOI2016/SHOI2016]侦察守卫
		$ \color{#0066ff}{ 题目描述 }$ 小R和B神正在玩一款游戏.这款游戏的地图由N个点和N-1条无向边组成,每条无向边连接两个点,且地图是连通的.换句话说,游戏的地图是一棵有N个节点的 ... 
- 洛谷P1351 联合权值(树形dp)
		题意 题目链接 Sol 一道很简单的树形dp,然而被我写的这么长 分别记录下距离为\(1/2\)的点数,权值和,最大值.以及相邻儿子之间的贡献. 树形dp一波.. #include<bits/s ... 
- 洛谷P4099 [HEOI2013]SAO(树形dp)
		传送门 HEOI的题好珂怕啊(各种意义上) 然后考虑树形dp,以大于为例 设$f[i][j]$表示$i$这个节点在子树中排名第$j$位时的总方案数(因为实际只与相对大小有关,与实际数值无关) 我们考虑 ... 
- 洛谷 P1351 联合权值 —— 树形DP
		题目:https://www.luogu.org/problemnew/show/P1351 树形DP,别忘了子树之间的情况(拐一下距离为2). 代码如下: #include<iostream& ... 
随机推荐
- ubuntu 下正确安装android手机驱动
			1. 查看手机ID号. charlesxue@THSHIBA:~/setup/cocos2d-x/cocos2d-x-/projects/simpleGame/proj.android/bin$ ls ... 
- javascript使用技巧总结,不断更新...
			1.使用a标签来获得当前页面相对地址的绝对地址 function getAbsoluteUrl(url){ var a; if(!a) a = document.createElement('a'); ... 
- SQL Server CLR全功略之一---CLR介绍和配置
			Microsoft SQL Server 现在具备与 Microsoft Windows .NET Framework 的公共语言运行时 (CLR) 组件集成的功能.CLR 为托管代码提供服务,例如跨 ... 
- 3-No resource found that matches the given name 'Theme.AppCompat.Light 的完美解决方案
			转载:http://www.360doc.com/content/15/0316/15/9200790_455576135.shtml 由于我在配置安卓环境时也碰到了类似问题,用这篇博客解决了主要问题 ... 
- rosbag数据记录及转换图片、视频
			博客转载自: https://blog.csdn.net/u012706484/article/details/78495896 rosbag常见的使用参数和配置 1.查看.bag中包含的信息 : r ... 
- Linux扩展根目录
			一.简介 使用linux系统的过程中,有时发现系统根目录(/)的空间不足,导致系统运行很慢,针对该现象,本文详细介绍根目录(/)的空间扩展方法. 二.操作步骤 1)查看根目录大小 df 2)查找系 ... 
- export default {} 和new Vue()区别
			1.export default 的用法:相当于提供一个接口给外界,让其他文件通过 import 来引入使用. 而对于export default 和export的区别: 在JavaScript ... 
- Jmeter跨线程组调用token
			BeanShell PostProcessor使用 1.正则提取token后添加:后置处理器-->BeanShell PostProcessor 2.BeanShell PostProcesso ... 
- 分享一个好用的功能强大的节点树jQuery插件
			http://www.treejs.cn/ 
- java实现wc功能
			github项目地址:https://github.com/3216004717/ruanjiangongcheng.git 项目相关要求 基本要求 wc.exe -c file.c //返回文件 f ... 
