結果
問題 | No.157 2つの空洞 |
ユーザー |
![]() |
提出日時 | 2019-09-26 16:46:35 |
言語 | Python3 (3.13.1 + numpy 2.2.1 + scipy 1.14.1) |
結果 |
AC
|
実行時間 | 32 ms / 2,000 ms |
コード長 | 707 bytes |
コンパイル時間 | 121 ms |
コンパイル使用メモリ | 12,672 KB |
実行使用メモリ | 10,880 KB |
最終ジャッジ日時 | 2024-09-23 08:00:05 |
合計ジャッジ時間 | 1,434 ms |
ジャッジサーバーID (参考情報) |
judge1 / judge3 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 4 |
other | AC * 16 |
ソースコード
W,H=map(int,input().split()) pa=[[[0,1][x=='.'] for x in input()] for y in range(H)] def fx(y,x,na,nb): if not 0<=y<H: return 0 if not 0<=x<W: return 0 n=pa[y][x] if n>=nb: return 0 if n> na: return 1 pa[y][x]=nb if n<=0: return 0 if fx(y-1,x,na,nb): return 1 if fx(y+1,x,na,nb): return 1 if fx(y,x-1,na,nb): return 1 if fx(y,x+1,na,nb): return 1 return 0 def fy(): nb=2 for na in range(1,40): for y in range(H): for x in range(W): n=pa[y][x] if n==na: if fx(y,x,na,nb): return nb-2 nb+=1 return 1 print(fy())