Let us define a magic grid to be a square matrix of integers of size $n \times n$, satisfying the following conditions.
- All integers from $0$ to $(n^2 – 1)$ inclusive appear in the matrix exactly once.
- Bitwise XOR of all elements in a row or a column must be the same for each row and column.
You are given an integer $n$ which is a multiple of $4$. Construct a magic grid of size $n \times n$.
Input
The only line of input contains an integer $n$ ($4 \leq n \leq 1000$). It is guaranteed that $n$ is a multiple of $4$.
Output
Print a magic grid, i.e. $n$ lines, the $i$-th of which contains $n$ space-separated integers, representing the $i$-th row of the grid.
If there are multiple answers, print any. We can show that an answer always exists.
Examples
input
4
output
8 9 1 13 3 12 7 5 0 2 4 11 6 10 15 14
input
8
output
19 55 11 39 32 36 4 52 51 7 35 31 12 48 28 20 43 23 59 15 0 8 16 44 3 47 27 63 24 40 60 56 34 38 6 54 17 53 9 37 14 50 30 22 49 5 33 29 2 10 18 46 41 21 57 13 26 42 62 58 1 45 25 61
Note
In the first example, XOR of each row and each column is $13$.
In the second example, XOR of each row and each column is $60$.
Solution:
#include <bits/stdc++.h> using namespace std; int main() { ios::sync_with_stdio(false); cin.tie(0); int n; cin >> n; vector<vector<int>> a(n, vector<int>(n)); int x = 0; for (int i = 0; i < n; i += 4) { for (int j = 0; j < n; j += 4) { for (int ii = 0; ii < 4; ii++) { for (int jj = 0; jj < 4; jj++) { a[i + ii][j + jj] = x++; } } } } for (int i = 0; i < n; i++) { for (int j = 0; j < n; j++) { if (j > 0) cout << " "; cout << a[i][j]; } cout << '\n'; } return 0; }