#include using namespace std; typedef long long ll; typedef vector vi; typedef vector vvi; #define rep(i,n) for(ll i=0;i<(n);i++) #define pii pair #define piii pair #define mp make_pair #define pb push_back #define ALL(a) (a).begin(),(a).end() #define FST first #define SEC second const int INF = INT_MAX; const ll LLINF = LLONG_MAX; const double eps = 1e-5; const double PI = M_PI; #define DEB cerr<<"!"< Array; typedef vector matrix; typedef tuple tiii; #define mt make_tuple ll pow(ll x,ll n,ll m){ll r=1;while(n>0){if(n&1==1)r=r*x%m;x=x*x%m;n>>=1;}return r%m;} int m; bool t[1000000] = {}; void sol(int a,int b){ if(a == b && !t[a]){cout << a << " "; return;} int mid = (a + b)/2; if(!t[mid]){ t[mid] = 1; cout << mid << " "; sol(mid,m); sol(2,mid); } return; } int main(){ int k; cin >> k; if( k == 2){cout << 1 << " "<< 2 << " " << 3 << endl; return 0;} m = pow(2,k,LLINF) - 1; sol(2,m); cout << 1; for(int i = 2; i <= m; i++) if(!t[i]) cout << " " << i; cout << endl; return 0; }