#include #include #include using namespace atcoder; using mint = modint998244353; using namespace std; #define rep(i,n) for (int i = 0; i < (n); ++i) #define Inf 1000000001 int main(){ int N; cin>>N; vector> ans(N,vector(N)); rep(i,N){ rep(j,N){ ans[i][j] = i*N+j+1; } } rep(i,N){ rep(j,N/2){ if((i%4==0||i%4==3)&&(j%4==1||j%4==2)){ swap(ans[i][j],ans[N-1-i][N-1-j]); } if((i%4==1||i%4==2)&&(j%4==0||j%4==3)){ swap(ans[i][j],ans[N-1-i][N-1-j]); } } } int X,Y,Z; cin>>X>>Y>>Z; X--;Y--; swap(X,Y); int x,y; rep(i,N){ rep(j,N){ if(ans[i][j]==Z){ x = i; y = j; } } } while(x!=X){ auto t = ans.back(); ans.pop_back(); ans.insert(ans.begin(),t); x++; x%=N; } while(y!=Y){ rep(i,N){ int t = ans[i].back(); ans[i].pop_back(); ans[i].insert(ans[i].begin(),t); } y++; y%=N; } rep(i,N){ rep(j,N){ if(j!=0)cout<<' '; cout<