#include typedef long long ll; using namespace std; int INF = 1e9; int MOD = 1e9+7; char C[20][21]; int dist[20][20]; int H,W; void update(int y,int x){ dist[y][x] = 0; for(int i = 0;i < H;i++){ for(int j = 0;j < W;j++){ dist[i][j] = min(dist[i][j],abs(i-y)+abs(j-x)); } } } void dfs(int y,int x){ if(y == -1 || y == H || x == -1 || x == W)return; if(C[y][x] == '#')return; C[y][x] = '#'; update(y,x); int dx[] = {1,0,-1,0},dy[] = {0,1,0,-1}; for(int k = 0;k < 4;k++)dfs(y+dy[k],x+dx[k]); } main(){ fill(dist[0],dist[20],INF); cin >> W >> H; for(int i = 0;i < H;i++)cin >> C[i]; for(int i = 0;i < H;i++){ for(int j = 0;j < W;j++){ if(C[i][j] == '.'){ dfs(i,j); goto breakloop; } } } breakloop: int mindist = INF; for(int i = 0;i < H;i++){ for(int j = 0;j < W;j++){ // printf("%d%c",dist[i][j],j==W-1?'\n':' '); if(C[i][j] == '.')mindist = min(mindist,dist[i][j]); } } cout << mindist-1 << endl; }