HDU 1521 排列组合(母函数)

题目链接
思路

指数型母函数板子题,网上教程一大抄,不错的教程,里面有普通母函数和指数型母函数教程
感觉普通母函数用背包就能瞎搞过。
这里就当存一波自己的板子,用了滚动数组,并且不需要第一次的初始化

代码
#include <stdio.h>
#include <string.h>

int fac[15] = {1};
double dp[2][15];

int main()
{
    int n, m, w;
    for(int i = 1; i < 11; ++i) fac[i] = i*fac[i-1];
    while(~scanf("%d%d",&n,&m))
    {
        int cur = 0;
        memset(dp[cur], 0, sizeof(dp[cur]));
        dp[cur][0] = 1.0;
        for(int i = 0; i < n; ++i)
        {
            cur ^= 1;
            memset(dp[cur], 0, sizeof(dp[cur]));
            scanf("%d",&w);
            for(int j = 0; j <= m; ++j)
            {
                for(int k = 0; k <= w && k+j <= m; ++k)
                {
                    dp[cur][j+k] += dp[cur^1][j] / fac[k];
                }
            }
        }
        printf("%.0f\n",dp[cur][m]*fac[m]);
    }
    return 0;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值