[백준] 5427. 불
2020. 4. 21. 17:05
https://www.acmicpc.net/problem/5427
5427번: 불
문제 상근이는 빈 공간과 벽으로 이루어진 건물에 갇혀있다. 건물의 일부에는 불이 났고, 상근이는 출구를 향해 뛰고 있다. 매 초마다, 불은 동서남북 방향으로 인접한 빈 공간으로 퍼져나간다. 벽에는 불이 붙지 않는다. 상근이는 동서남북 인접한 칸으로 이동할 수 있으며, 1초가 걸린다. 상근이는 벽을 통과할 수 없고, 불이 옮겨진 칸 또는 이제 불이 붙으려는 칸으로 이동할 수 없다. 상근이가 있는 칸에 불이 옮겨옴과 동시에 다른 칸으로 이동할 수 있다. 빌딩
www.acmicpc.net
시뮬레이션 + BFS 문제 였습니다.
(상근이가 있는 칸에 불이 옮겨옴과 동시에 다른 칸으로 이동할 수 있다.) << 동시에 라는 말에 고민하지말고 순차적으로 구현
(불이 옮겨진 칸 또는 이제 불이 붙으려는 칸으로 이동할 수 없다.) << 이 지문때문에 불이 먼저 번지도록 구현
- 불 동서남북 번짐 -> 벽만 아니면 불이 번지도록
- 상근이 움직임 -> 빈칸인 곳 으로만 움직일 수 있음
상근이가 움직일 수 있는 곳을 담은 Queue가 텅 비었을땐 탈출 불가능한 것이고,
움직이는 도중 map밖으로 상근이가 이동하면 그때까지 걸린 총 시간을 출력하면 됩니다.
* 불과 상근이가 방문한 곳을 체크하는 boolean 배열을 2개 사용합니다.
'Algorithm & Data Structure > BOJ' 카테고리의 다른 글
[백준] 9501. 꿍의 우주여행 (0) | 2020.04.23 |
---|---|
[백준] 4179. 불! (0) | 2020.04.22 |
[백준] 1837. 암호제작 (0) | 2020.04.20 |
[백준] 5014. 스타트링크 (BFS) (0) | 2020.04.03 |
[백준] 1748. 수 이어 쓰기 1 (0) | 2020.04.02 |