标签:san 不同 cst pre name and 思考 int sans
描述
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; }
标签:san 不同 cst pre name and 思考 int sans
原文地址:http://www.cnblogs.com/uncle-lu/p/6003164.html