#include<bits/stdc++.h>
using namespace std;
int n,m,lx,ly,a,b,c,ux,uy;
struct guji{
int x,y;
};
guji u,tmp,note;
queue<guji> q;
int ans[410][410];
int walk[8][2]={{2,1},{2,-1},{-2,1},{-2,-1},{1,-2},{1,2},{-1,-2},{-1,2}};
int main(){
memset(ans,-1,sizeof(ans));
cin >> n >> m >> lx >> ly;
note={lx,ly};
q.push(note);
ans[lx][ly]=0;
while(!q.empty()){
u=q.front();
ux=u.x;
uy=u.y;
q.pop();
for(int i=0;i<8;i++){
a=ux+walk[i][0];
b=uy+walk[i][1];
c=ans[ux][uy];
if(a<1||a>n||b<1||b>n||ans[a][b]!=-1){
continue;
}
ans[a][b]=c+1;
tmp={a,b};
q.push(tmp);
}
}
for(int i=1;i<=n;i++){
for(int j=1;j<=m;j++){
cout << ans[i][j] << " ";
}
cout << endl;
}
return 0;
}