|
|
#include <iostream>
#include <cstdio> #include <cstring> #include <cmath> #include <climits> #include <algorithm> using namespace std; const int maxn=100+1; const int mm=1000007; int a[maxn]; int f[maxn][maxn]; int n,m; int main() { scanf("%d%d",&n,&m); for (int i=1; i<=n; i++) scanf("%d",&a[i]); for (int i=0; i<=n; i++) f[0][i]=1; for (int i=1; i<=m; i++) for (int j=1; j<=n; j++) for (int k=0; k<=min(i,a[j]); k++) { f[i][j]=(f[i][j]+f[i-k][j-1])%mm; } printf("%d\n",f[m][n]); return 0; } |
|
学习记忆化搜索
|
|
0.0
|
|
|
|
论1和i的区别
论1000000007和1000007的区别
题目 1270 [NOIP 2012]摆花
2016-10-07 19:19:31
|
|
初值又设置错了。。。。
题目 1270 [NOIP 2012]摆花
2016-05-04 12:56:23
|
|
加滚动会不会快一点…
|
|
|