#include <cstdio>
#include <cstring>
#include <iostream>
#include <queue>
#include <algorithm>
using namespace std;
int n,m,now,K,L;
char str[810][810];
int f[810][810],len[810][810],r1[810],r2[810],vis[810],ans[810][810];
inline int rd()
{
int ret=0,f=1; char gc=getchar();
while(gc<‘0‘||gc>‘9‘) {if(gc==‘-‘)f=-f; gc=getchar();}
while(gc>=‘0‘&&gc<=‘9‘) ret=ret*10+gc-‘0‘,gc=getchar();
return ret*f;
}
bool cmp(int a,int b)
{
return len[now][a]>len[now][b];
}
int main()
{
scanf("%d%d%d%d",&n,&m,&K,&L);
int i,j,*p=r1,*q=r2,tp;
for(i=1;i<=n;i++) scanf("%s",str[i]+1);
for(j=m;j;j--) for(i=1;i<=n;i++) len[j][i]=(str[i][j]==‘0‘)?0:(len[j+1][i]+1);
for(j=1;j<=m;j++)
{
now=j,tp=0;
for(i=1;i<=n;i++) if(len[j][i]&&!vis[i]) p[++tp]=i;
sort(p+1,p+tp+1,cmp);
if(j!=1)
{
sort(q+1,q+K+1,cmp);
for(i=1;i<=L&&i<=tp;i++) if(len[j][p[i]]>len[j][q[K-i+1]]) swap(p[i],q[K-i+1]);
if(i!=K+1&&!len[j][q[K-i+1]])
{
printf("1");
return 0;
}
memset(vis,0,sizeof(vis));
swap(p,q);
}
else
{
if(tp<K)
{
printf("1");
return 0;
}
}
for(i=1;i<=K;i++) vis[p[i]]=1,ans[j][i]=p[i];
swap(p,q);
}
for(j=1;j<=m;j++) for(i=1;i<=K;i++) printf("%d%c",ans[j][i],i==K?‘\n‘:‘ ‘);
return 0;
}/*
4 4 3 1
1110
1101
1011
0111
*/