#include <iostream>
#include <cmath>
#include <vector>
#include <string.h>
#include <bits/stdc++.h>
#include <cstdlib>
#include <time.h>
#include <fstream>
#include <iterator>
#include <utility>
#include <algorithm>
#include <set>
#include <map>
#include <bitset>
using namespace std;
#define ll long long
#define ull unsigned ll
#define ld long double
typedef vector<int> vi;
typedef multiset<int> mi;
typedef multiset<ll> mll;
typedef vector<ll> vll;
typedef vector<bool> vb;
typedef vector<string> vs;
typedef vector<vector<int>> _2vi;
typedef vector<vector<ll>> _2vll;
#define all(v) ((v).begin()), ((v).end())
#define sz(v) ((ll)((v).size()))
#define vinp(v, n) \
for (ull i = 0; i < (n); i++) \
cin >> (v)[i]
#define printv(v) \
for (auto i : (v)) \
cout << i << " "
#define fr0(i, n) for (ull(i) = 0; (i) < (n); (i)++)
#define fr1(i, n) for (ull(i) = 1; (i) < (n); (i)++)
#define fr(i, x, n) for (ull(i) = (x); (i) < (n); (i)++)
#define _CRT_SECURE_NO_WARNING
const ll MOD = 1000000007;
void Bustany() {
ios_base::sync_with_stdio(false);
cin.tie(NULL);
cout.tie(NULL);
#ifndef ONLINE_JUDGE
freopen("./in.txt", "r", stdin), freopen("./out.txt", "w", stdout);
#endif
}
ll n;
ll u, r, d, l;
ll c = 0;
_2vll v;
void fun(ll i, ll j, char direction) {
cout << v[i][j] << " ";
c++;
if (c != 0 && c % n == 0) {
cout << endl;
}
if (c == (n * n)) {
return;
}
if (direction == 'r' && j < r) {
fun(i, j + 1, 'r');
} else if (direction == 'r') {
u++;
fun(i + 1, j, 'd');
}
if (direction == 'd' && i < d) {
fun(i + 1, j, 'd');
} else if (direction == 'd') {
r--;
fun(i, j - 1, 'l');
}
if (direction == 'l' && j > l) {
fun(i, j - 1, 'l');
} else if (direction == 'l') {
d--;
fun(i - 1, j, 'u');
}
if (direction == 'u' && i > u) {
fun(i - 1, j, 'u');
} else if(direction=='u') {
l++;
fun(i, j + 1, 'r');
}
}
void solve() {
cin >> n;
v.resize(n, vll(n));
u = 0, r = n - 1, d = n - 1, l = 0;
fr0(i, n) {
fr0(j, n) {
cin >> v[i][j];
}
}
fun(0, 0, 'r');
}
int main() {
Bustany();
ll t = 1;
// cin >> t;
while (t--) {
solve();
}
}
I2luY2x1ZGUgPGlvc3RyZWFtPgojaW5jbHVkZSA8Y21hdGg+CiNpbmNsdWRlIDx2ZWN0b3I+CiNpbmNsdWRlIDxzdHJpbmcuaD4KI2luY2x1ZGUgPGJpdHMvc3RkYysrLmg+CiNpbmNsdWRlIDxjc3RkbGliPgojaW5jbHVkZSA8dGltZS5oPgojaW5jbHVkZSA8ZnN0cmVhbT4KI2luY2x1ZGUgPGl0ZXJhdG9yPgojaW5jbHVkZSA8dXRpbGl0eT4KI2luY2x1ZGUgPGFsZ29yaXRobT4KI2luY2x1ZGUgPHNldD4KI2luY2x1ZGUgPG1hcD4KI2luY2x1ZGUgPGJpdHNldD4KCnVzaW5nIG5hbWVzcGFjZSBzdGQ7CgojZGVmaW5lIGxsIGxvbmcgbG9uZwojZGVmaW5lIHVsbCB1bnNpZ25lZCBsbAojZGVmaW5lIGxkIGxvbmcgZG91YmxlCnR5cGVkZWYgdmVjdG9yPGludD4gdmk7CnR5cGVkZWYgbXVsdGlzZXQ8aW50PiBtaTsKdHlwZWRlZiBtdWx0aXNldDxsbD4gbWxsOwp0eXBlZGVmIHZlY3RvcjxsbD4gdmxsOwp0eXBlZGVmIHZlY3Rvcjxib29sPiB2YjsKdHlwZWRlZiB2ZWN0b3I8c3RyaW5nPiB2czsKdHlwZWRlZiB2ZWN0b3I8dmVjdG9yPGludD4+IF8ydmk7CnR5cGVkZWYgdmVjdG9yPHZlY3RvcjxsbD4+IF8ydmxsOwojZGVmaW5lIGFsbCh2KSAoKHYpLmJlZ2luKCkpLCAoKHYpLmVuZCgpKQojZGVmaW5lIHN6KHYpICgobGwpKCh2KS5zaXplKCkpKQoKI2RlZmluZSB2aW5wKHYsIG4pICAgICAgICAgICAgICAgIFwKICAgIGZvciAodWxsIGkgPSAwOyBpIDwgKG4pOyBpKyspIFwKICAgIGNpbiA+PiAodilbaV0KI2RlZmluZSBwcmludHYodikgICAgICBcCiAgICBmb3IgKGF1dG8gaSA6ICh2KSkgXAogICAgY291dCA8PCBpIDw8ICIgIgojZGVmaW5lIGZyMChpLCBuKSBmb3IgKHVsbChpKSA9IDA7IChpKSA8IChuKTsgKGkpKyspCiNkZWZpbmUgZnIxKGksIG4pIGZvciAodWxsKGkpID0gMTsgKGkpIDwgKG4pOyAoaSkrKykKI2RlZmluZSBmcihpLCB4LCBuKSBmb3IgKHVsbChpKSA9ICh4KTsgKGkpIDwgKG4pOyAoaSkrKykKI2RlZmluZSBfQ1JUX1NFQ1VSRV9OT19XQVJOSU5HCmNvbnN0IGxsIE1PRCA9IDEwMDAwMDAwMDc7Cgp2b2lkIEJ1c3RhbnkoKSB7CiAgICBpb3NfYmFzZTo6c3luY193aXRoX3N0ZGlvKGZhbHNlKTsKICAgIGNpbi50aWUoTlVMTCk7CiAgICBjb3V0LnRpZShOVUxMKTsKI2lmbmRlZiBPTkxJTkVfSlVER0UKICAgIGZyZW9wZW4oIi4vaW4udHh0IiwgInIiLCBzdGRpbiksIGZyZW9wZW4oIi4vb3V0LnR4dCIsICJ3Iiwgc3Rkb3V0KTsKI2VuZGlmCn0KCmxsIG47CmxsIHUsIHIsIGQsIGw7CmxsIGMgPSAwOwpfMnZsbCB2OwoKdm9pZCBmdW4obGwgaSwgbGwgaiwgY2hhciBkaXJlY3Rpb24pIHsKICAgIGNvdXQgPDwgdltpXVtqXSA8PCAiICI7CiAgICBjKys7CiAgICBpZiAoYyAhPSAwICYmIGMgJSBuID09IDApIHsKICAgICAgICBjb3V0IDw8IGVuZGw7CiAgICB9CiAgICBpZiAoYyA9PSAobiAqIG4pKSB7CiAgICAgICAgcmV0dXJuOwogICAgfQoKCiAgICBpZiAoZGlyZWN0aW9uID09ICdyJyAmJiBqIDwgcikgewogICAgICAgIGZ1bihpLCBqICsgMSwgJ3InKTsKICAgIH0gZWxzZSBpZiAoZGlyZWN0aW9uID09ICdyJykgewogICAgICAgIHUrKzsKICAgICAgICBmdW4oaSArIDEsIGosICdkJyk7CiAgICB9CgoKICAgIGlmIChkaXJlY3Rpb24gPT0gJ2QnICYmIGkgPCBkKSB7CiAgICAgICAgZnVuKGkgKyAxLCBqLCAnZCcpOwogICAgfSBlbHNlIGlmIChkaXJlY3Rpb24gPT0gJ2QnKSB7CiAgICAgICAgci0tOwogICAgICAgIGZ1bihpLCBqIC0gMSwgJ2wnKTsKICAgIH0KCgogICAgaWYgKGRpcmVjdGlvbiA9PSAnbCcgJiYgaiA+IGwpIHsKICAgICAgICBmdW4oaSwgaiAtIDEsICdsJyk7CiAgICB9IGVsc2UgaWYgKGRpcmVjdGlvbiA9PSAnbCcpIHsKICAgICAgICBkLS07CiAgICAgICAgZnVuKGkgLSAxLCBqLCAndScpOwogICAgfQoKCiAgICBpZiAoZGlyZWN0aW9uID09ICd1JyAmJiBpID4gdSkgewogICAgICAgIGZ1bihpIC0gMSwgaiwgJ3UnKTsKICAgIH0gZWxzZSBpZihkaXJlY3Rpb249PSd1JykgewogICAgICAgIGwrKzsKICAgICAgICBmdW4oaSwgaiArIDEsICdyJyk7CiAgICB9Cn0KCgp2b2lkIHNvbHZlKCkgewogICAgY2luID4+IG47CiAgICB2LnJlc2l6ZShuLCB2bGwobikpOwogICAgdSA9IDAsIHIgPSBuIC0gMSwgZCA9IG4gLSAxLCBsID0gMDsKICAgIGZyMChpLCBuKSB7CiAgICAgICAgZnIwKGosIG4pIHsKICAgICAgICAgICAgY2luID4+IHZbaV1bal07CiAgICAgICAgfQogICAgfQogICAgZnVuKDAsIDAsICdyJyk7Cn0KCmludCBtYWluKCkgewogICAgQnVzdGFueSgpOwogICAgbGwgdCA9IDE7Ci8vICAgICBjaW4gPj4gdDsKICAgIHdoaWxlICh0LS0pIHsKICAgICAgICBzb2x2ZSgpOwogICAgfQp9