P1077 [NOIP2012 普及组] 摆花
链接: link.
#include<bits/stdc++.h>
using namespace std;
int dp[110],a[110];
const int mod=1e6+7;
int main()
{
int n,m;
cin>>n>>m;
for(int i=1;i<=n;i++)
{
cin>>a[i];
}
dp[0]=1;
for(int i=1;i<=n;i++)
{
for(int j=m;j>=0;j--)
{
for(int x=1;x<=min(a[i],j);x++)
{
dp[j]=dp[j]+dp[j-x];
dp[j]=dp[j]%mod;
}
}
}
cout<<dp[m]<<endl;
}