#define _CRT_SECURE_NO_WARNINGS #include <stdio.h> #include<iostream> #include<vector> #include<cstring> #include<queue> #include<algorithm> using namespace std; //把M个同样的苹果放在N个同样的盘子里,允许有的盘子空着不放 //问共有多少种不同的分法?(用K表示)5,1,1和1,5,1 是同一种分法。 //每行均包含二个整数M和N,以空格分开。1<=M,N<=10。 //对输入的每组数据M和N,用一行输出相应的K。 int main() { int m, n;//m表示苹果, n表示盘子 scanf("%d %d", &m, &n); int dp[11][11]; memset(dp, 0, 11 * 11);//初始化 //如果苹果个数为0或者1 for (int i = 1; i <= n; i++) { dp[0][i] = 1; dp[1][i] = 1; } //如果盘子个数为1 for (int i = 1; i <= m; i++) { dp[i][1] = 1; } for (int i = 2; i <= m; i++) { for (int j = 2; j <= n; j++) { if (i < j) { //当苹果数小于盘子数 dp[i][j] = dp[i][i]; } else { //苹果数大于或等于盘子数 dp[i][j] = dp[i][j - 1] + dp[i - j][j];//至少有一个空盘子和所有盘子都放满 } } } printf("%d\n", dp[m][n]); return 0; }