#pragma GCC target("avx") #pragma GCC optimize("Ofast") #pragma GCC optimize("unroll-loops") #include using namespace std; int main() { cin.tie(0); ios::sync_with_stdio(false); int N; cin >> N; int cnt = 0; vector rem(2*N-1); stack> stc; iota(rem.begin(), rem.end(), 1); for( int i = 0; i < 2*N-1; i++ ) { stc.emplace((vector){i}); } cout << 2*N-1 << endl; while( !stc.empty() ) { vector p = stc.top(); stc.pop(); for( int& x : p ) { if( rem[x] == 0 ) goto LABEL; } if( p.size() == N ) { ++cnt; for( int& x : p ) { --rem[x]; cout << x+1 << ' '; } cout << '\n'; }else { for( int ls = 0, B = p.back(); ls < B; ++ls ) { if( rem[ls] > 0 ) { p.emplace_back(ls); stc.push(p); p.pop_back(); } } } LABEL: {} } if( N == 2 ) { cout << "3 2 \n"; }else if( N == 3 ) { cout << "5 4 3 \n"; } }