1029.巧分整数

题意:

将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;
}
全部评论

相关推荐

不愿透露姓名的神秘牛友
11-27 10:48
点赞 评论 收藏
分享
沉淀一会:1.同学你面试评价不错,概率很大,请耐心等待; 2.你的排名比较靠前,不要担心,耐心等待; 3.问题不大,正在审批,不要着急签其他公司,等等我们! 4.预计9月中下旬,安心过节; 5.下周会有结果,请耐心等待下; 6.可能国庆节前后,一有结果我马上通知你; 7.预计10月中旬,再坚持一下; 8.正在走流程,就这两天了; 9.同学,结果我也不知道,你如果查到了也告诉我一声; 10.同学你出线不明朗,建议签其他公司保底! 11.同学你找了哪些公司,我也在找工作。
点赞 评论 收藏
分享
评论
点赞
收藏
分享
牛客网
牛客企业服务