当前位置:网站首页>codeforces k-Tree (dp仍然不会耶)
codeforces k-Tree (dp仍然不会耶)
2022-08-02 14:23:00 【先求一个导】
题目
题意: 给定一棵树,每个节点恰好有k个儿子,对应的边恰好为1-k. 求一下有多少种方案,满足路径上的权值恰好为n,且至少有一个边满足边权>=d.
思路: 其实就是个线性dp,每一层只能选1-k.好久没dp就d不出来了,可以先dp一遍1-k都能用的,再dp一遍只能用1-(d-1)的,相减就是满足题意的.f[0][i][j]: 用全部边,从前i层中选,边权恰好为j的方案数。只需枚举当前这一层用多少权值,即可递推出。f[0][i][j] = f[0][i-1][j-1…k]
只依赖于上一层,所以可以把i这一维给压缩掉。f[0][j] = f[0][j-1…k]
时间复杂度: O(n* n * k)或O(n*k)
代码:
#include<bits/stdc++.h>
using namespace std;
const int N = 102;
const int mod = 1e9+7;
int n,m,k,T;
int f[2][N]; //0:所有边,1:小于d的边,f[j]:权值为j的方案数
void solve()
{
cin>>n>>k>>m;
f[0][0] = 1;
for(int j=1;j<=n;++j) //权值
{
for(int t=1;t<=k;++t) //枚举从哪转移
{
if(j-t<0) break;
f[0][j] = (f[0][j] + f[0][j-t]) % mod;
}
}
k = m-1;
f[1][0] = 1;
for(int j=1;j<=n;++j) //权值
{
for(int t=1;t<=k;++t) //枚举从哪转移
{
if(j-t<0) break;
f[1][j] = (f[1][j] + f[1][j-t]) % mod;
}
}
long long ans = 0;
ans = (ans + f[0][n]) % mod;
ans = (ans - f[1][n]) % mod;
ans = (ans + mod) % mod;
cout<<ans;
}
signed main(void)
{
solve();
return 0;
}
边栏推荐
猜你喜欢
随机推荐
Filter 过滤器
【数据知多少】一文学懂通过Tushare、AKshare、baostock、Ashare、Pytdx获取股票行情数据(含代码)
JSP技术
2021年度总结——收获圆满的一年
web渗透之sql注入
js电梯导航基础案例
常见(MySQL)面试题(含答案)
2022/7/15,我的人生中第一篇博客,不忘初心,砥砺前行!
为什么四个字节的float表示的范围比八个字节的long要广
2021 Huawei Cup Mathematical Modeling Contest E question - Ultra-Wideband (UWB) precise positioning problem under signal interference
EL 表达式 & JSTL 标签库
【JS执行机制】
DOM —— 事件代理
nvm管理node版本 nodenpm不是内部或外部命令,也不是可运行的程序
炎炎夏日打造一个属于自己的“便携小空调”吧
数据源,分层开发以及jsp标签总结及相关代码
2022-07-26 第六小组 瞒春 学习笔记
【Anaconda】一行语句解决Spyder启动问题
解决(An error happened during template parsing (template: “class path resource [templates/...]
ADB常用命令--测试人员必备