码迷,mamicode.com
首页 > 其他好文 > 详细

[dp] hdu 4472 Count

时间:2015-09-11 19:17:21      阅读:152      评论:0      收藏:0      [点我收藏+]

标签:

意甲冠军:

鉴于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

标签:

原文地址:http://www.cnblogs.com/bhlsheji/p/4801504.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!