题目描述 Description
将整数n分成k份,且每份不能为空,任意两种划分方案不能相同(不考虑顺序)。
例如:n=7,k=3,下面三种划分方案被认为是相同的。
1 1 5
1 5 1
5 1 1
问有多少种不同的分法。
输入描述 Input Description
输入:n,k (6<n<=200,2<=k<=6)
输出描述 Output Description
输出:一个整数,即不同的分法。
样例输入 Sample Input
7 3
样例输出 Sample Output
4
数据范围及提示 Data Size & Hint
{四种分法为:1,1,5;1,2,4;1,3,3;2,2,3;}
思路:
划分k份,每份都不为空。
用f【i】【j】表示 将 i 划分为 j 份 的方案数。
初始化:因任何数划分为 1 份,都是其本身,故 f【i】【0】=1。
考虑两种情况;
第一,每一份都不为 1 ,那么可得将每一份都减1的情况,且并不影响此时 f 的值
第二,至少有一份为1,说明有一份已被1占领。
将两种情况相加,即是当前的值
f 【i】【j】= f【i-j】【j】+ f【i-1】【j-1】;
可以发现只有当 i>=j 时,才能满足上诉条件。
| |