题意:一棵树选择恰好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)的更多相关文章

  1. BZOJ5314: [Jsoi2018]潜入行动

    BZOJ5314: [Jsoi2018]潜入行动 https://lydsy.com/JudgeOnline/problem.php?id=5314 分析: 裸树形背包,设\(f[x][i][0/1] ...

  2. [bzoj5314][Jsoi2018]潜入行动_树形背包dp

    潜入行动 bzoj-5314 Jsoi-2018 题目大意:题目链接. 注释:略. 想法: 学长给我们除了一套考试题,三个学长一人一道这是T1. 好吧好吧,傻逼背包...... 复杂度$O(nk)$. ...

  3. BZOJ5314 [Jsoi2018]潜入行动 【背包类树形dp】

    题目链接 BZOJ5314 题解 设\(f[i][j][0|1][0|1]\)表示\(i\)为根的子树,用了\(j\)个监测器,\(i\)节点是否被控制,\(i\)节点是否放置的方案数 然后转移即可 ...

  4. LOJ 2546 「JSOI2018」潜入行动——树形DP

    题目:https://loj.ac/problem/2546 dp[ i ][ j ][ 0/1 ][ 0/1 ] 表示 i 子树,用 j 个点,是否用 i , i 是否被覆盖. 注意 s1<= ...

  5. [JSOI2018]潜入行动 (树形背包)

    题目链接 题意: 外星人的母舰可以看成是一棵 n 个节点. n−1 条边的无向树,树上的节点用 1,2,⋯,n 编号.JYY 的特工已经装备了隐形模块,可以在外星人母舰中不受限制地活动,可以神不知鬼不 ...

  6. [JSOI2018]潜入行动 树形DP_复杂计数

    code #include <cstdio> #include <algorithm> #include <cstring> #include <string ...

  7. [loj2546][JSOI2018]潜入行动(树形DP)

    题目描述 外星人又双叒叕要攻打地球了,外星母舰已经向地球航行!这一次,JYY 已经联系好了黄金舰队,打算联合所有 JSOIer 抵御外星人的进攻. 在黄金舰队就位之前,JYY 打算事先了解外星人的进攻 ...

  8. 【BZOJ5314】[JSOI2018]潜入行动(动态规划)

    [BZOJ5314][JSOI2018]潜入行动(动态规划) 题面 BZOJ 洛谷 题解 不难想到一个沙雕\(dp\),设\(f[i][j][0/1][0/1]\)表示当前点\(i\),子树中一共放了 ...

  9. BZOJ5314:[JSOI2018]潜入行动——题解

    https://www.lydsy.com/JudgeOnline/problem.php?id=5314 https://www.luogu.org/problemnew/show/P4516 ht ...

随机推荐

  1. Python开发【面向对象编程】

    一.概述 面向过程:根据业务逻辑从上到下,完成代码: 函数式:将某功能代码封装到函数中,日后便无需重复编写,仅调用函数即可: 面向对象:对函数进行分类和封装. 二.面向对象 1.类.对象.方法.实例 ...

  2. Lunix

    1.Lunix系统登录.重启.关闭 ①.登录 ②.重启 ③.关闭:shutdown [选项][时间][警告信息] -k 向所有用户发出警告信息 -r 关机后立即重启 -h 关机后不重新启动 -f 快速 ...

  3. 在Unity中接入Xbox360手柄

    提要 本文主要介绍了怎样在Unity中接入Xbox360的手柄. 当我们调Input.GetAxis("Horizontal"),我们调了什么 Unity中全部关于输入的设置都在E ...

  4. HDU 1379:DNA Sorting

    DNA Sorting Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) Tota ...

  5. [Codeforces Round 486A] Fair

    [题目链接] https://codeforces.com/contest/986/problem/A [算法] 用dist(i,j)表示第i种食物运到第j个城市需要的最小代价 将所有特产为第i中食物 ...

  6. Springboot 相关注解大全

    1.Spring注解 1.@Autowired 标注在方法,Spring容器创建当前对象,就会调用方法,完成赋值:方法使用的参数,自定义类型的值从ioc容器中获取自动装配; Spring利用依赖注入( ...

  7. C++面向对象程序设计_Part2

    目录 Composition(复合) 内存视角下的composition(复合) composition(复合)关系下的构造与析构 Delegation (委託) -- Composition by ...

  8. qW3xT.2挖矿病毒处理方案

    我遇到的是一款qW3xT.2的病毒,网上查了一下,好像是挖矿病毒.在此贴一下我找到的关于病毒的资料.这是我的服务器 这篇文章可谓是出自高手之笔,感觉说的很厉害,但是非专业人士的我有点看不懂,看个大概  ...

  9. 大数高精度加减乘除 51nod 1005 大数加法

    1005 大数加法 基准时间限制:1 秒 空间限制:131072 KB 分值: 0 难度:基础题  收藏  关注 给出2个大整数A,B,计算A+B的结果. Input 第1行:大数A 第2行:大数B ...

  10. 启动tomcat报错:ImageFormatException

    启动某工程报错: java.lang.NoClassDefFoundError: com/sun/image/codec/jpeg/ImageFormatException 查找此类存在于jdk的rt ...