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

bzoj2287:[POJ Challenge]消失之物

时间:2016-10-29 18:52:46      阅读:163      评论:0      收藏:0      [点我收藏+]

标签:main   cpp   blog   mat   hal   预处理   公式   namespace   put   

思路:首先先背包预处理出f[x]表示所有物品背出体积为x的方案数。然后统计答案,利用dp。

C[i][j]表示不用物品i,组成体积j的方案数。

转移公式:C[i][j]=f[j]-C[i][j-w[i]]

#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<cmath>
using namespace std;
#define maxn 2005
 
int n,m;
int f[maxn],w[maxn],ans[maxn];
 
int main(){
    scanf("%d%d",&n,&m);
    for (int i=1;i<=n;i++) scanf("%d",&w[i]);f[0]=1;
    for (int i=1;i<=n;i++)
        for (int j=m;j>=w[i];j--)
            f[j]+=f[j-w[i]],f[j]%=10;
    for (int i=1;i<=n;i++){
        memset(ans,0,sizeof(ans)),ans[0]=1;
        for (int j=1;j<=m;j++){
            if (j>=w[i]) ans[j]=((f[j]-ans[j-w[i]])%10+10)%10;
            else ans[j]=f[j];
            printf("%d",ans[j]);
        }
        puts("");
    }
    return 0;
}

 

bzoj2287:[POJ Challenge]消失之物

标签:main   cpp   blog   mat   hal   预处理   公式   namespace   put   

原文地址:http://www.cnblogs.com/DUXT/p/6011340.html

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