def count_paths(n, m): # 创建一个 (n+1) x (m+1) 的二维列表来存储中间结果 dp = [[0] * (m + 1) for _ in range(n + 1)] # 第一行所有位置都只有一种走法(一直往右走) for i in range(1, n + 1): dp[i][0] = 1 # 第一列所有位置都只有一种走法(一直往下走) for j in range(1, m + 1): dp[0][j] = 1 # 通过动态规划递推计算每个位置的走法数 for i in range(1, n + 1): for j in range(1, m + 1): # 当前位置的走法数等于上面位置的走法数加上左边位置的走法数 dp[i][j] = dp[i - 1][j] + dp[i][j - 1] # 返回右下角位置的走法数 return dp[n][m] n, m = map(int, input().split()) print(count_paths(n, m))