繁繁的数字 背包DP

Posted santiego

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了繁繁的数字 背包DP相关的知识,希望对你有一定的参考价值。

繁繁的数字 背包DP

问一个数(n)有多少种二进制分解方案数

(nle 10^5)

如7有7=4+2+1=4+1+1+1=2+2+2+1=2+2+1+1+1=2+1+1+1+1+1=1+1+1+1+1+1+1,共6种方案

一眼完全背包,将(2^0,2^1cdots)等看成(log_n)个物品,每个物品无限件,背包体积为(n)。然后求方案数套个计数DP即可。

其他机房大佬都是找规律找出来的……

#include <cstdio>
#define MAXN 1000010
#define MOD 1000000007
#define ll long long
using namespace std;
int n;
ll f[MAXN];
int main()
{
    //freopen("number.in","r",stdin);
    //freopen("number.out","w",stdout);
    scanf("%d", &n);
    f[0]=1;
    int tmp=0;
    for(int i=0;tmp=(1<<i),tmp<=n;++i){
        for(int j=0;j<=n;++j)
            if(j>=tmp)
                f[j]=(f[j]+f[j-tmp])%MOD;
    }
    printf("%lld", f[n]);
    return 0;
}

以上是关于繁繁的数字 背包DP的主要内容,如果未能解决你的问题,请参考以下文章

繁繁的游戏

TYVJ1096 数字组合 - 背包DP[01背包]

HDU 5119 Happy Matt Friends ——(背包DP)

TYVJ1172 自然数拆分Lunatic版 - 背包DP[完全背包]

bzoj 1025[SCOI2009]游戏 - 背包dp

秦皇岛 I 题