結果
| 問題 |
No.157 2つの空洞
|
| コンテスト | |
| ユーザー |
Bantako
|
| 提出日時 | 2017-08-08 21:22:52 |
| 言語 | C++14 (gcc 13.3.0 + boost 1.87.0) |
| 結果 |
AC
|
| 実行時間 | 2 ms / 2,000 ms |
| コード長 | 1,127 bytes |
| コンパイル時間 | 1,686 ms |
| コンパイル使用メモリ | 167,312 KB |
| 実行使用メモリ | 5,248 KB |
| 最終ジャッジ日時 | 2024-10-12 00:16:56 |
| 合計ジャッジ時間 | 2,248 ms |
|
ジャッジサーバーID (参考情報) |
judge5 / judge4 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 4 |
| other | AC * 16 |
コンパイルメッセージ
main.cpp:25:1: warning: ISO C++ forbids declaration of 'main' with no type [-Wreturn-type]
25 | main(){
| ^~~~
ソースコード
#include<bits/stdc++.h>
typedef long long ll;
using namespace std;
int INF = 1e9;
int MOD = 1e9+7;
char C[20][21];
int dist[20][20];
int H,W;
void update(int y,int x){
dist[y][x] = 0;
for(int i = 0;i < H;i++){
for(int j = 0;j < W;j++){
dist[i][j] = min(dist[i][j],abs(i-y)+abs(j-x));
}
}
}
void dfs(int y,int x){
if(y == -1 || y == H || x == -1 || x == W)return;
if(C[y][x] == '#')return;
C[y][x] = '#';
update(y,x);
int dx[] = {1,0,-1,0},dy[] = {0,1,0,-1};
for(int k = 0;k < 4;k++)dfs(y+dy[k],x+dx[k]);
}
main(){
fill(dist[0],dist[20],INF);
cin >> W >> H;
for(int i = 0;i < H;i++)cin >> C[i];
for(int i = 0;i < H;i++){
for(int j = 0;j < W;j++){
if(C[i][j] == '.'){
dfs(i,j);
goto breakloop;
}
}
}
breakloop:
int mindist = INF;
for(int i = 0;i < H;i++){
for(int j = 0;j < W;j++){
// printf("%d%c",dist[i][j],j==W-1?'\n':' ');
if(C[i][j] == '.')mindist = min(mindist,dist[i][j]);
}
}
cout << mindist-1 << endl;
}
Bantako