//简单深搜
#include<bits/stdc++.h>
using namespace std;
long long ans = 0;
int n, k;
bool vis[210];
void dfs(int x, int la, int dep)
{
if(dep == k + 1)
{
if(x == 0)
ans++;
return;
}
for(int i = la;i <= x;i++)
{
if(x - i >= 0)
dfs(x - i, i, dep + 1);
}
}
int main()
{
cin >> n >> k;
dfs(n, 1, 1);
cout << ans << endl;
return 0;
}