#include <algorithm>
#include <cmath>
#include <cstdio>
#include <functional>
#include <iostream>
#include <map>
#include <numeric>
#include <queue>
#include <set>
#include <stack>
#include <string>
#include <vector>
using namespace std;
using ll = long long;
int main() {
  int n;
  cin >> n;
  vector<int> a(n, 0);
  for(int i = 0; i < n; i++) {
    if(i % 2 == 0) {
      a[i] = (i + 2) / 2;
    } else {
      a[i] = (i + 2) / 2 + (n + 1) / 2;
    }
  }
  for(int i = 0; i < n; i++) {
    a.push_back(a[i]);
  }

  for(int i = 0; i < n; i++) {
    for(int j = 0; j < n; j++) {
      cout << a[i + j] << " ";
    }
    cout << '\n';
  }
  return 0;
}