#include<cstdio>
#include<cstring>
#include<algorithm>
#include<cmath>
using namespace std;
int n,m,cnt1,cnt2;
char s[155][155];
bool f,vis[155][155];
int xi[5]={0,0,1,0,-1},yi[5]={0,1,0,-1,0};
struct node{
int x,y;
}q[155*155];
void dfs(int xx,int yy,char c){
int head=0,tail=1;
q[0].x=xx; q[0].y=yy; vis[xx][yy]=1;
while(head!=tail){
int x=q[head].x,y=q[head].y; head++;
for(int i=1;i<=4;i++){
int sx=x+xi[i],sy=y+yi[i];
if(sx>=0&&sx<=n+1&&sy>=0&&sy<=m+1&&s[sx][sy]==c&&!vis[sx][sy]){
q[tail].x=sx; q[tail].y=sy;
tail++; vis[sx][sy]=1;
}
}
}
}
int main()
{
while(scanf("%d %d",&n,&m)==2){
memset(vis,0,sizeof(vis));
for(int i=1;i<=n;i++) scanf("%s",s[i]+1);
cnt1=0; cnt2=0;
for(int i=0;i<=m+1;i++) s[0][i]=‘0‘,s[n+1][i]=‘0‘;
for(int i=0;i<=n+1;i++) s[i][0]=‘0‘,s[i][m+1]=‘0‘;
for(int i=0;i<=n+1;i++)
for(int j=0;j<=m+1;j++)if(!vis[i][j]){
if(s[i][j]==‘1‘) cnt1++;
else cnt2++;
dfs(i,j,s[i][j]);
}
if(cnt1==1&&cnt2==2) printf("0\n");
else if(cnt1==1&&cnt2==1) printf("1\n");
else printf("-1\n");
}
return 0;
}