题意:

将n分成k个数,每个数不能为0,分法不能重复(不考虑顺序)

思路:

神奇的dp!

dp[i] [j] = dp[i - j] [j - 1] + dp[i - j] [j] (dp[i] [j]指将i分成j份)

因为每个数不能为0,所以对于数i,先减去j,得到能支配的数,在将这些数进行分配。所以dp[i] [j] = dp[i - j] [1] + dp[i - j] [2] + …… + dp[i - j] [j]。都是这样不太好处理,所以进行一次简化。

dp[i - 1] [j - 1] = d p[i - 1 - (j - 1)] [1] + ……dp[i - 1 - (j - 1)] [j - 1] = dp[i - j] [1] + dp[i - j] [2] +……dp[i - j] [j - 1] = dp[i] [j] - dp[i - j] [j]

所以dp[i] [j] = dp[i - 1] [j - 1] + dp[i - j] [j].

#include<bits/stdc++.h>
using  namespace std;
#define MAX 1000+5
typedef  long long ll ;
int tr[MAX][10], n, q;
int main()
{
    cin>>n>>q;
    memset(tr, 0, sizeof(tr));
    tr[0][0] = 1;
    for(int i = 1; i <= n; i++)
    {
        for(int j = 1; j <= q; j++)
        {
            if(i >= j)
                tr[i][j] = tr[i - 1][j - 1] + tr[i - j][j];
        }
    }
    cout<<tr[n][q]<<endl;
    return 0;
}