百练 2755 神奇的口袋 dp背包

描述
有一个神奇的口袋,总的容积是40,用这个口袋可以变出一些物品,这些物品的总体积必须是40。John现在有n个想要得到的物品,每个物品的体积分别是a 1,a 2……a n。John可以从这些物品中选择一些,如果选出的物体的总体积是40,那么利用这个神奇的口袋,John就可以得到这些物品。现在的问题是,John有多少种不同的选择物品的方式。
输入
输入的第一行是正整数n (1 <= n <= 20),表示不同的物品的数目。接下来的n行,每行有一个1到40之间的正整数,分别给出a 1,a 2……a n的值。
输出
输出不同的选择物品的方式的数目。
样例输入
3
20
20
20
样例输出
3

  • 查看 
  • 提交 
  • 统计 
  • 提示 
  • 提问
    • ACcode:
    • #pragma warning(disable:4786)//使命名长度不受限制
      #pragma comment(linker, "/STACK:102400000,102400000")//手工开栈
      #include <map>
      #include <set>
      #include <queue>
      #include <cmath>
      #include <stack>
      #include <cctype>
      #include <cstdio>
      #include <cstring>
      #include <stdlib.h>
      #include <iostream>
      #include <algorithm>
      #define rd(x) scanf("%d",&x)
      #define rd2(x,y) scanf("%d%d",&x,&y)
      #define rds(x) scanf("%s",x)
      #define rdc(x) scanf("%c",&x)
      #define ll long long int
      #define maxn 105
      #define mod 1000000007
      #define INF 0x3f3f3f3f //int 最大值
      #define FOR(i,f_start,f_end) for(int i=f_start;i<=f_end;++i)
      #define MT(x,i) memset(x,i,sizeof(x))
      #define PI  acos(-1.0)
      #define E  exp(1)
      using namespace std;
      int a[maxn],dp[maxn][maxn],n;///DP表示前j种拼凑出i体积的方法数
      int main(){
          while(rd(n)!=EOF){
              MT(dp,0);
              FOR(i,1,n){
                  rd(a[i]);dp[0][i]=1;
              }
              dp[0][0]=1;
              FOR(w,1,40)
                  FOR(k,1,n){
                      dp[w][k]=dp[w][k-1];
                      if(w-a[k]>=0)
                          dp[w][k]+=dp[w-a[k]][k-1];
                      //cout<<w<<"    "<<k<<"     "<<dp[w][k]<<'\12';
                  }
              printf("%d\n",dp[40][n]);
          }
          return 0;
      }
      /*
      3
      20
      20
      20
      */
      


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值