結果
| 問題 | No.157 2つの空洞 |
| コンテスト | |
| ユーザー |
|
| 提出日時 | 2020-04-18 18:23:33 |
| 言語 | C++17 (gcc 15.2.0 + boost 1.89.0) |
| 結果 |
AC
|
| 実行時間 | 1 ms / 2,000 ms |
| コード長 | 1,044 bytes |
| 記録 | |
| コンパイル時間 | 2,172 ms |
| コンパイル使用メモリ | 218,412 KB |
| 実行使用メモリ | 6,400 KB |
| 最終ジャッジ日時 | 2026-06-09 15:10:38 |
| 合計ジャッジ時間 | 2,312 ms |
|
ジャッジサーバーID (参考情報) |
judge2_1 / judge1_0 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 4 |
| other | AC * 16 |
ソースコード
#include <bits/stdc++.h>
#define rep(i,n) for(int i=0;i<(n);i++)
using namespace std;
const int dx[]={1,0,-1,0},dy[]={0,-1,0,1};
int main(){
int h,w; scanf("%d%d",&w,&h);
string B[20];
rep(i,h) cin>>B[i];
int i0=-1,j0=-1;
rep(i,h) rep(j,w) if(i0==-1 && B[i][j]=='.') { i0=i; j0=j; }
bool ini[20][20]={};
ini[i0][j0]=true;
queue<pair<int,int>> Q; Q.emplace(i0,j0);
while(!Q.empty()){
int y,x; tie(y,x)=Q.front(); Q.pop();
rep(k,4){
int yy=y+dy[k],xx=x+dx[k];
if(0<=yy && yy<h && 0<=xx && xx<w && B[yy][xx]=='.' && !ini[yy][xx]){
ini[yy][xx]=true;
Q.emplace(yy,xx);
}
}
}
int d[20][20]={};
rep(y,h) rep(x,w) {
if(ini[y][x]){
d[y][x]=0;
Q.emplace(y,x);
}
else{
d[y][x]=-1;
}
}
while(!Q.empty()){
int y,x; tie(y,x)=Q.front(); Q.pop();
rep(k,4){
int yy=y+dy[k],xx=x+dx[k];
if(0<=yy && yy<h && 0<=xx && xx<w && d[yy][xx]==-1){
d[yy][xx]=d[y][x]+1;
if(B[yy][xx]=='.'){
printf("%d\n",d[yy][xx]-1);
return 0;
}
Q.emplace(yy,xx);
}
}
}
return 0;
}