首页 > 代码库 > [dp] hdu 4472 Count
[dp] hdu 4472 Count
题意:
给出n个节点,满足同层节点的子节点个数相同的树有都少种不同的形态。
思路:
dp[i][j] 代表i个节点,最后一层有j个节点的方法
因为要满足同层节点数相同,所以j层的下一层一定是j 的整数倍
所以就能得到后续的状态
代码:
#include"cstdlib" #include"cstdio" #include"cstring" #include"cmath" #include"queue" #include"algorithm" #include"map" #define ll __int64 #include"iostream" using namespace std; ll dp[1234][1234],sum[1234]; ll mod=1000000007; int main() { int cas=1; memset(dp,0,sizeof(dp)); dp[1][1]=1; for(int i=1;i<=1000;i++) { for(int j=1;j<=1000;j++) { for(int k=j;k<=1000;k+=j) { if(i+k>1000) break; dp[i+k][k]=(dp[i+k][k]+dp[i][j])%mod; } sum[i]=(sum[i]+dp[i][j])%mod; } } ll n; while(scanf("%I64d",&n)!=-1) { printf("Case %d: %I64d\n",cas++,sum[n]); } return 0; }
[dp] hdu 4472 Count
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。