#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;
}