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 ...
随机推荐
- android菜鸟之路-事件分发机制总结(二)
ViewGroup事件分发机制 自己定义一个LinearLayout,ImageView和Button,小二,上代码 <LinearLayout xmlns:android="http ...
- 用block变量来对字符数组对象进行排序
<span style="font-size:18px;">降序排序</span> <span style="font-size:18px; ...
- 在C++代码中调用L脚本语言
L脚本语言同意被其他编程语言调用.如C++,非常easy.仅仅要在宿主语言中载入L脚本引擎的动态库 直接调用这两个函数就能够了 extern "C" int __stdcall S ...
- easyUI datagrid 时间格式化
从后台传过来的数据,其中含有日期字段,那么在前端的easyUI这里显示的话,会显得比较怪异,一大串,中间是个T,后面一大堆零,不知道是什么意思. 看来要进行格式化. 问题是,在哪里格式化? 如果在后端 ...
- 【bzoj3676】[Apio2014]回文串 —— 回文自动机的学习
写题遇上一棘手的题,[Apio2014]回文串,一眼看过后缀数组+Manacher.然后就码码码...过是过了,然后看一下[Status],怎么慢这么多,不服..然后就搜了一下,发现一种新东西——回文 ...
- 解决jQuery uploadify在非IE核心浏览器下无法上传
之前上传了一个通过Flash实现多文件上传,但是在IE正常运行,FireFox 不能正常上传.经过反复研究学习,之所以firefox和360浏览器无法正常运行,是因为FireFox.chrome.36 ...
- bzoj 1370 Gang团伙
题目大意: 在某城市里住着n个人,任何两个认识的人不是朋友就是敌人,满足 1. 我朋友的朋友是我的朋友 2. 我敌人的敌人是我的朋友 所有是朋友的人组成一个团伙 告诉你关于这n个人的m条信息,即某两个 ...
- 【USACO 2017FEB】 Why Did the Cow Cross the Road III
[题目链接] 点击打开链接 [算法] 树状数组 [代码] #include<bits/stdc++.h> using namespace std; #define MAXN 100010 ...
- 模块化编程:AMD规范
目前,通行的Javascript模块规范共有两种:ComonJS和AMD. CommonJS node.js的模块系统,就是参照CommonJS规范实现的.在ConmonJS中,有一个全局方法requ ...
- eclipse maven创建web项目
记录地址 jdk设置及文件包miss 实例下载地址 创建SSM整合项目 一.使用Eclipse中的maven插件创建web项目 1: 2: 3: 4: 5:maven web项目创建成功.(去掉ind ...