#include<queue>
#include<cmath>
#include<cstdio>
#include<vector>
#include<cstring>
#include<iostream>
#include<algorithm>
using namespace std;
typedef long long ll;
typedef unsigned long long ull;
const int N=410;
int dx[8]={-1,-2,-2,-1,1,2,2,1};
int dy[8]={2,1,-1,-2,2,1,-1,-2};
int n,m,x,y;
bool vis[N][N];
int ans[N][N];
struct edge{
int x,y;
};
queue<edge>q;
int bfs(int a,int b){
edge e;e.x=a;e.y=b;q.push(e);
while(!q.empty()){
edge st=q.front();q.pop();
for(int i=0;i<8;i++){
edge nx;nx.x=st.x+dx[i];nx.y=st.y+dy[i];
if(nx.x>=1&&nx.x<=n&&nx.y>=1&&nx.y<=m&&vis[nx.x][nx.y]==0){
vis[nx.x][nx.y]=1;
ans[nx.x][nx.y]=ans[st.x][st.y]+1;
q.push(nx);
}
}
}
}
int main(){
std::ios::sync_with_stdio(0);
cin.tie(0),cout.tie(0);
cin>>n>>m>>x>>y;
memset(ans,-1,sizeof(ans));
ans[x][y]=0;vis[x][y]=1;
bfs(x,y);
for(int i=1;i<=n;i++){
for(int j=1;j<=m;j++){
printf("%-5d",ans[i][j]);
}cout<<endl;
}
return 0;
}