//数组DP
#include<iostream>
using namespace std;
const int N=40;//给的范围是30,防止越界。
int n,m;
int f[N][N];
int main()
{
cin>>n>>m;
f[1][1]=1;
for(int i=1;i<=n;i++)
for(int j=1;j<=m;j++)
{
if(i==1&&j==1)continue;//如果是一行一列就输出f[1][1]
if(i%2 || j%2) f[i][j]=f[i-1][j]+f[i][j-1];//否则就执行该行
}
cout<<f[n][m]<<endl;
return 0;
}