#include<bits/stdc++.h>
int n,m,xt,yt,minn[409][409],dx[8]={1,2,2,1,-1,-2,-2,1},dy[8]={2,1,-1,-2,-2,-1,1,2},v[409][409];
using namespace std;
struct node
{
int x,y;
};
queue<node> q;
void bfs()
{
v[xt][yt]=1;
minn[xt][yt]=0;
node l={xt,yt};
q.push(l);
while(!q.empty())
{
cout<<"&";
node t=q.front();
q.pop();
for(int i=0;i<8;i++)
{
int xx=t.x+dx[i],yy=t.y+dy[i];
if(xx>0&&yy>0&&!v[xx][yy])
{
minn[xx][yy]=minn[t.x][t.y]+1;
node tt={xx,yy};
q.push(tt);
v[xx][yy]=1;
}
}
}
}
int main()
{
memset(minn,-1,sizeof(minn));
cin>>n>>m>>xt>>yt;
bfs();
for(int i=1;i<=n;i++)
{
for(int j=1;j<=m;j++) printf("%-5d",minn[i][j]);
cout<<endl;
}
return 0;
}