描述
5 5 1 2 3 4 5
3
分析:
Dynamic Programming。拿到这种题首先得思考,什么是状态,什么是转移。这道题里面由于是求方案数,很简单就可以想到用递推来求解。以第几位数作为一个阶段。将这个阶段前面所有的阶段的状态全部转移过来,而且还要将上一个状态可能创造新的状态加入这个阶段。
现在讲人话,F[i][j]代表前第i个数,可以组成j的组数.之后就一点一点往后转移就好,只是在转移的时候不要忘了,不加当前第i个数不加当前数的所有状态.
#include<cstdio>
#include<algorithm>
using namespace std;
int f[25][1010],t,n,line[30],k;
int main()
{
scanf("%d%d",&n,&k);
for(int i=1;i<=n;++i)
{
scanf("%d",&line[i]);
f[i][line[i]]=1;
}
for(int i=2;i<=n;++i)
{
for(int j=1;j<line[i];++j)f[i][j]+=f[i-1][j];
for(int j=line[i];j<=k;++j)
{
f[i][j]+=(f[i-1][j]+f[i-1][j-line[i]]);
}
}
printf("%d",f[n][k]);
return 0;
}
原文:http://www.cnblogs.com/uncle-lu/p/6003164.html