比较毒瘤的树形DP,子状态难想。这是主要是搬运一篇题解。

用\(f[i][j]\)表示\(i\)的子树中离\(i\)最近黑点的距离为\(j\),且距离超过\(j\)的点都被满足的方案数。转移时新建一个临时数组\(tmp\)保存转移后的\(f[x]\)。设\(y\)是\(x\)的子结点,枚举\(f[x][i]\)和\(f[y][j]\),转移如下:

  1. 若\(i+j≤2k\),则此时\(min(i,j+1)≤k\),对于长度为\(i+j+1\)的链上的所有点都可以找到一边距离\(≤k\),因此状态合并以后是合法状态,转移\(tmp[min(i,j+1)]+=f[x][i]×f[y][j]\);

  2. 若\(i+j>2k\),则此时\(max(i,j+1)>k\),链上肯定会存在一些点两边都够不到,转移\(tmp[max(i,j+1)]+=f[x][i]×f[y][j]\)。

初始状态\(f[x][0]=1\),表示不考虑子树内的情况,选择自己的方案数为\(1\);\(f[x][k+1]=1\),表示自己本身不满足,但子结点都被满足的情况,主要是方便转移。

答案为\(∑i<=kf[root][i]\)。

时间复杂度\(O(nk2)\)。

代码如下

#include<cstdio>
#include<cctype>
#include<algorithm>
#include<forward_list>
typedef long long int64;
inline int getint() {
register char ch;
while(!isdigit(ch=getchar()));
register int x=ch^'0';
while(isdigit(ch=getchar())) x=(((x<<2)+x)<<1)+(ch^'0');
return x;
}
const int N=101,K=41,mod=1e9+7;
int k,f[N][K],tmp[K];
std::forward_list<int> e[N];
inline void add_edge(const int &u,const int &v) {
e[u].push_front(v);
e[v].push_front(u);
}
void dfs(const int &x,const int &par) {
f[x][0]=f[x][k+1]=1;
for(int &y:e[x]) {
if(y==par) continue;
dfs(y,x);
std::fill(&tmp[0],&tmp[k*2]+1,0);
for(register int i=0;i<=k*2;i++) {
for(register int j=0;j<=k*2;j++) {
(tmp[i+j<=k*2?std::min(i,j+1):std::max(i,j+1)]+=(int64)f[x][i]*f[y][j]%mod)%=mod;
}
}
std::copy(&tmp[0],&tmp[k*2]+1,f[x]);
}
}
int main() {
const int n=getint();k=getint();
for(register int i=1;i<n;i++) {
add_edge(getint(),getint());
}
dfs(1,0);
int ans=0;
for(register int i=0;i<=k;i++) {
(ans+=f[1][i])%=mod;
}
printf("%d\n",ans);
return 0;
}

最新文章

  1. 使用SQLServer同义词和SQL邮件,解决发布订阅中订阅库丢失数据的问题
  2. fabric devenv Vagrantfile配置
  3. ps中的位图,矢量图,颜色模式
  4. 云端卫士实战录 | Java高级特性之多线程
  5. java-pfx文件转换成16进制内容
  6. Android Afinal框架(二)
  7. C++实现01串排序
  8. android下的数据存储
  9. Comet技术浅论
  10. iOS Foundation框架 -4.NSDate类的简单用法
  11. 【回忆1314】抽奖之Flash大转盘
  12. 简单js
  13. iOS开发之MapKit
  14. Java第一季
  15. Shiro Remember me设置
  16. vue js校验金钱、数字
  17. TF模型训练中注意Loss和F1的变化情况
  18. 【LeetCode刷题】SQL-Second Highest Salary 及扩展以及Oracle中的用法
  19. 形成一个zigzag数组(JPEG编码里取像素数据的排列顺序)
  20. #leetcode刷题之路40-组合总和 II

热门文章

  1. C# XML 反序列化解析
  2. &lt;constant name=&quot;struts.devMode&quot; value=&quot;true&quot; /&gt;
  3. exceptional c++ 读书笔记 一 . vector 的使用
  4. 数论(同余+hash)
  5. Java&amp;amp;Xml教程(十一)JAXB实现XML与Java对象转换
  6. 通过PowerShell卸载全部的SharePoint 2010 解决方式
  7. nyoj--120--校园网络(scc+缩点)
  8. Linux性能优化和监控系列(一)——top工具
  9. [SCOI 2007] 排列
  10. input file上传文件