結果
| 問題 |
No.157 2つの空洞
|
| コンテスト | |
| ユーザー |
|
| 提出日時 | 2015-02-26 23:49:35 |
| 言語 | Ruby (3.4.1) |
| 結果 |
AC
|
| 実行時間 | 90 ms / 2,000 ms |
| コード長 | 507 bytes |
| コンパイル時間 | 525 ms |
| コンパイル使用メモリ | 7,296 KB |
| 実行使用メモリ | 12,416 KB |
| 最終ジャッジ日時 | 2024-06-23 21:45:59 |
| 合計ジャッジ時間 | 3,499 ms |
|
ジャッジサーバーID (参考情報) |
judge4 / judge2 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 4 |
| other | AC * 16 |
コンパイルメッセージ
Syntax OK
ソースコード
def g;gets.split.map(&:to_i)end
w,h=g
c=(0...h).map{gets+?+}+[?+*w]
fx=fy=0
fy=(0...h).find{|i|fx=(0...w).find{|j|c[i][j]==?.}}
q=[[fx,fy,0]]
c[fy][fx]=?+
n=0
while q[n]
x,y=q[n]
[[x+1,y],[x-1,y],[x,y+1],[x,y-1]].each{|tx,ty|
if c[ty][tx]==?.
q<<[tx,ty,0]
c[ty][tx]=?+
end
}
n+=1
end
while q[0]
x,y,i=q.shift
[[x+1,y],[x-1,y],[x,y+1],[x,y-1]].each{|tx,ty|
case c[ty][tx]
when ?.
p i
exit
when ?#
q<<[tx,ty,i+1]
c[ty][tx]=?+
end
}
end