#include<iostream>
#include<algorithm>
#include<cstring>
#include<math.h>
#include<iomanip>
using namespace std;
int zh[505][505], temp[505][505];;
void shun(int x, int y, int r) {
for (int i = x - r; i <= x + r; i++) {
for (int j = y - r; j <= y + r; j++) {
zh[i][j] = temp[i][j];
}
}
int x1 = x + r, y1 = y - r;
for (int i = x - r; i <= x + r; i++) {
for (int j = x - r; j <= x + r; j++) {
temp[i][j] = zh[x1][y1];
x1--;
}
x1 = x + r, y1++;
}
}
void ni(int x, int y, int r) {
for (int i = x - r; i <= x + r; i++) {
for (int j = y - r; j <= y + r; j++) {
zh[i][j] = temp[i][j];
}
}
int x1 = x - r, y1 = y + r;
for (int i = x - r; i <= x + r; i++) {
for (int j = x - r; j <= x + r; j++) {
temp[i][j] = zh[x1][y1];
x1++;
}
x1 = x - r, y1--;
}
}
int main(){
int n,m,num=1;
int x, y, r, z;
cin >> n >> m;
for (int i = 1; i <= n; i++) {
for (int j = 1; j <= n; j++) {
temp[i][j] = num++;
}
}
for (int i = 0; i < m; i++) {
cin >> x >> y >> r >> z;
if (z == 0) {
shun(x, y, r);
}
else if (z == 1) {
ni(x, y, r);
}
}
for (int i = 1; i <= n; i++) {
for (int j = 1; j <= n; j++) {
cout << temp[i][j] << " ";
}
cout << endl;
}
return 0;
}