HDU 1521 排列组合(母函数)

版权声明:没人会转的( ̄▽ ̄) https://blog.csdn.net/j2_o2/article/details/84671477
题目链接
思路

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

代码
#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;
}

猜你喜欢

转载自blog.csdn.net/j2_o2/article/details/84671477