BZOJ5314: [Jsoi2018]潜入行动 (树形DP)
题意:一棵树选择恰好k个结点放置监听器
每个监听器只能监听相邻的节点
问能使得所有节点被监听的种类数
题解:反正就是很well-known的树形DP了
至于时间复杂度为什么是nk 不会不学
很好想到四维dp 在x节点放置j个 x有没有放监听器 x有没有被监听
瞎搞搞就好了 头写昏了转移就抄别人了的TAT
关键是这个题开ll会mle 不开会爆int 取%频繁还会tle
西安太热了!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
#include <stdio.h>
#include <algorithm>
#include <iostream>
#include <string.h>
using namespace std;
typedef long long ll;
const ll mod = ;
int n, k; struct node
{
int to, nex;
}E[];
int head[];
int sz[];
int dp[][][][]; //放不放 被占用没
ll tmp[][][]; inline void add(int &x,ll y)
{
if(x + y >= mod) x = x + y - mod;
else x = x + y;
} void dfs(int x, int fa)
{
sz[x] = ;
dp[x][][][] = ; //放
dp[x][][][] = ; //不放
int c = head[x];
for(int i = c; i; i = E[i].nex)
{
int v = E[i].to;
if(v == fa) continue;
dfs(v, x); int tx = min(k, sz[x]);
int tv = min(k, sz[v]);
for(int j = ; j <= tx; j++)
for(int jj = ; jj < ; jj++)
for(int jjj = ; jjj < ; jjj++)
tmp[j][jj][jjj] = dp[x][j][jj][jjj], dp[x][j][jj][jjj] = ; for(int j = ; j <= tx; j++)
{
for(int jj = ; jj <= tv && j + jj <= k; jj++)
{
add(dp[x][j + jj][][], tmp[j][][] * dp[v][jj][][] % mod);
add(dp[x][j + jj][][], (tmp[j][][] * dp[v][jj][][] + tmp[j][][] * (dp[v][jj][][] + dp[v][jj][][]))%mod);
add(dp[x][j + jj][][], tmp[j][][] * (dp[v][jj][][] + dp[v][jj][][]) % mod);
add(dp[x][j + jj][][], (tmp[j][][] * (dp[v][jj][][] + dp[v][jj][][]) + tmp[j][][] * (dp[v][jj][][] + dp[v][jj][][]) + tmp[j][][] * (dp[v][jj][][] + dp[v][jj][][]))%mod);
}
}
sz[x] += sz[v];
}
} int main()
{
int cnt = ;
scanf("%d%d", &n, &k);
for(int i = ; i < n; i++)
{
int u, v; scanf("%d%d", &u, &v);
E[++cnt].to = v; E[cnt].nex = head[u]; head[u] = cnt;
E[++cnt].to = u; E[cnt].nex = head[v]; head[v] = cnt;
}
dfs(, -);
printf("%lld\n", (dp[][k][][] + dp[][k][][]) % mod);
return ;
}
BZOJ5314: [Jsoi2018]潜入行动 (树形DP)的更多相关文章
- BZOJ5314: [Jsoi2018]潜入行动
BZOJ5314: [Jsoi2018]潜入行动 https://lydsy.com/JudgeOnline/problem.php?id=5314 分析: 裸树形背包,设\(f[x][i][0/1] ...
- [bzoj5314][Jsoi2018]潜入行动_树形背包dp
潜入行动 bzoj-5314 Jsoi-2018 题目大意:题目链接. 注释:略. 想法: 学长给我们除了一套考试题,三个学长一人一道这是T1. 好吧好吧,傻逼背包...... 复杂度$O(nk)$. ...
- BZOJ5314 [Jsoi2018]潜入行动 【背包类树形dp】
题目链接 BZOJ5314 题解 设\(f[i][j][0|1][0|1]\)表示\(i\)为根的子树,用了\(j\)个监测器,\(i\)节点是否被控制,\(i\)节点是否放置的方案数 然后转移即可 ...
- LOJ 2546 「JSOI2018」潜入行动——树形DP
题目:https://loj.ac/problem/2546 dp[ i ][ j ][ 0/1 ][ 0/1 ] 表示 i 子树,用 j 个点,是否用 i , i 是否被覆盖. 注意 s1<= ...
- [JSOI2018]潜入行动 (树形背包)
题目链接 题意: 外星人的母舰可以看成是一棵 n 个节点. n−1 条边的无向树,树上的节点用 1,2,⋯,n 编号.JYY 的特工已经装备了隐形模块,可以在外星人母舰中不受限制地活动,可以神不知鬼不 ...
- [JSOI2018]潜入行动 树形DP_复杂计数
code #include <cstdio> #include <algorithm> #include <cstring> #include <string ...
- [loj2546][JSOI2018]潜入行动(树形DP)
题目描述 外星人又双叒叕要攻打地球了,外星母舰已经向地球航行!这一次,JYY 已经联系好了黄金舰队,打算联合所有 JSOIer 抵御外星人的进攻. 在黄金舰队就位之前,JYY 打算事先了解外星人的进攻 ...
- 【BZOJ5314】[JSOI2018]潜入行动(动态规划)
[BZOJ5314][JSOI2018]潜入行动(动态规划) 题面 BZOJ 洛谷 题解 不难想到一个沙雕\(dp\),设\(f[i][j][0/1][0/1]\)表示当前点\(i\),子树中一共放了 ...
- BZOJ5314:[JSOI2018]潜入行动——题解
https://www.lydsy.com/JudgeOnline/problem.php?id=5314 https://www.luogu.org/problemnew/show/P4516 ht ...
随机推荐
- 【OI】单调队列
所谓单调队列,就是一个保持着某种性质的队列,通常是队列从队头到队尾,维护一种递增递减的关系. 这种队列通常用来解决一些连续区间的最值问题. 这种队列的入队要保证符合当前的性质,例如一个递增的单调序列( ...
- Bootstrap 过渡效果 transition.js源码分析
前言: 阅读建议:去github下载一个完整dom然后把,本篇代码复制进去然后运行就好了以地址 Bootstrap 自带的 JavaScript 插件的动画效果几乎都是使用 CSS 过渡实现的,那么判 ...
- 蓝桥 PREV-34 历届试题 矩阵翻硬币
历届试题 矩阵翻硬币 时间限制:1.0s 内存限制:256.0MB 问题描述 小明先把硬币摆成了一个 n 行 m 列的矩阵. 随后,小明对每一个硬币分别进行一次 Q 操作. 对第 ...
- 【Codevs3151】交通管制I
Position: http://codevs.cn/problem/3151/ List [Codevs3151]交通管制I List Description Input Output Sample ...
- 洛谷 P2615 神奇的幻方 —— 模拟
题目:https://www.luogu.org/problemnew/show/P2615 直接按题意模拟即可; 用 Emacs 做的第一道题! 代码如下: #include<iostream ...
- 栗染-Myeclispe连接SQL Server数据库
第一步,在SQL server方面 这里是以身份验证登录. 这里我是建了一个hw的数据库,其他没啥说的. 第二步,最主要的一部分 因为第一次连接SQL Server数据库,所以就不知道还有这一步.不然 ...
- 略微讲讲最近的 webpack 该如何加快编译
首先假设 基础的环境是有 creat-react-app 所创建的 即所有基础的loader,插件的 cache 都已经缓存了 在这种情况下想加速,真是很难 不过,有一个插件是可以观察 各个模块所花的 ...
- 【杂文】虚拟键码表(供函数GetAsyncKeyState()使用)
[杂文]虚拟键码表(供函数GetAsyncKeyState()使用) 什么?你说你不知道 \(GetAsyncKeyState()\) ?\(→\)戳我\(←\) (惊奇的发现 \(0\) ~ \(9 ...
- phpAnalysis调试接口
phpAnalysis是一款轻量级非侵入式PHP应用性能分析器,适用于开发.测试及生产环境部署使用,方便开发及测试工程师诊断性能问题: 通过tideways收集PHP程序单步运行过程中所有的函数调用时 ...
- Linux学习笔记之Linux用户与用户组、文件操作命令、文件权限剖析
1.用户与用户组 Linux是一个多用户操作系统,通过用户与用户组的概念,可以实现保证安全性和隐私性.任何一个文件都具有User.Group.Others三个权限. 文件拥有者(Linux下所有的东西 ...