縦に n 行、横に n 列並べられた、合計 n × n のマス目があります。いくつかのマス目には印がついています。各マス目の印の状態を読み込み、印のついていないマス目だけからなる最大の正方形の辺の長さを出力として表示するプログラムを作成してください。
たとえば各データセットで以下のようなデータが与えられます。
10 ...*....** .......... **....**.. ........*. ..*....... .......... .*........ .......... ....*..*** .*....*...
入力データの一行が、一行のマス目を表現します。入力データの文字列のうち、.(ピリオド)は印のついていないマス目、*(アスタリスク)は印のついているマス目を示しています。
上記の例では、下図の 0 で示される正方形が最大となります。
...*....** .......... **....**.. ...00000*. ..*00000.. ...00000.. .*.00000.. ...00000.. ....*..*** .*....*...
よって、5 と出力すれば正解になります。
なお、すべてのマス目に印がついている場合には、0 を出力してください。
上記形式で複数のデータセットが与えられます。 n が 0 のとき入力の最後とします。n は 1000 以下とします。入力データの文字列には、ピリオド、アスタリスク、改行以外の文字は含まれません。データセットの数は 50 を超えません。
各データセットに対し、最大の正方形の辺の長さ(整数)を1行に出力して下さい。
10 ...*....** .......... **....**.. ........*. ..*....... .......... .*........ .......... ....*..*** .*....*... 10 ****.***** *..*.*.... ****.*.... *....*.... *....***** .......... ****.***** *..*...*.. ****...*.. *..*...*.. 0
5 3