-
描述
- 有一个神奇的口袋,总的容积是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 */