#include <iostream>
using namespace std;
const int N = 30;
int n, m;
bool st[N];
void dfs(int u, int s) //s用来记录当前选了几个数
{
if (s == m)
{
for (int i = 1; i <= n; i ++ )
if (st[i])
cout << i << ' ';
cout << endl;
return;
}
if (u > n) return;
st[u] = true; //题目要求按字典序排序,即从小的数开始选
dfs(u + 1, s +1); //第一种情况s + 1,选择当前数
st[u] = false; //恢复现场
dfs(u + 1, s); //第二种情况s不变,即不选当前数
}
int main()
{
cin >> n >> m;
dfs(1, 0);
return 0;
}