#include #include using namespace std; const int M=3000; int main() { int h,w;cin>>h>>w; int c[M+1][M+1],dp[M+1][M+1]={}; char a; for(int i=1;i<=h;i++)for(int j=1;j<=w;j++) { cin>>a; c[i][j]=(a=='#'?0:1); } int ma=0; for(int i=1;i<=h;i++) { for(int j=1;j<=w;j++) { if(!c[i][j])dp[i][j]=min(dp[i][j-1],min(dp[i-1][j-1],dp[i-1][j]))+1,ma=max(ma,dp[i][j]); } } cout<<(ma+1)/2<