using System; namespace YukiMe2_6{ public class Program{ public static void Main(string[] args){ var sr = new StreamReader(); //--------------------------------- var H = sr.Next(); var W = sr.Next(); var dp = new int[H + 2, W + 2]; var max = 0; for(var i = 1; i <= H; i++){ var input = sr.Next(); for(var j = 1; j <= W; j++){ if(input[j - 1] == '#'){ max = Math.Max(max, dp[i, j] = Math.Min(dp[i - 1, j - 1], Math.Min(dp[i - 1, j], dp[i, j - 1])) + 1); } else{ dp[i, j] = 0; } } } Console.WriteLine((max + 1) / 2); //--------------------------------- } } public class StreamReader{ private readonly char[] _c = {' '}; private int _index = -1; private string[] _input = new string[0]; public T Next(){ if(_index == _input.Length - 1){ _index = -1; while(true){ string rl = Console.ReadLine(); if(rl == null){ if(typeof(T).IsClass) return default(T); return (T)typeof(T).GetField("MinValue").GetValue(null); } if(rl != ""){ _input = rl.Split(_c, StringSplitOptions.RemoveEmptyEntries); break; } } } return (T)Convert.ChangeType(_input[++_index], typeof(T), System.Globalization.CultureInfo.InvariantCulture); } } }