출처 : https://www.acmicpc.net/problem/4179
불! 성공
시간 제한 | 메모리 제한 | 제출 | 정답 | 맞은 사람 | 정답 비율 |
---|---|---|---|---|---|
1 초 | 128 MB | 2134 | 478 | 337 | 22.527% |
문제
지훈이는 미로에서 일을 한다. 지훈이를 미로에서 탈출하도록 도와주자!
미로에서의 지훈이의 위치와 불이 붙은 위치를 감안해서 지훈이가 불에 타기전에 탈출할 수 있는지의 여부, 그리고 얼마나 빨리 탈출할 수 있는지를 결정해야한다.
지훈이와 불은 매 분마다 한칸씩 수평또는 수직으로(비스듬하게 이동하지 않는다) 이동한다.
불은 각 지점에서 네 방향으로 확산된다.
지훈이는 미로의 가장자리에 접한 공간에서 탈출할 수 있다.
지훈이와 불은 벽이 있는 공간은 통과하지 못한다.
입력
입력의 첫째 줄에는 공백으로 구분된 두 정수 R과 C가 주어진다. 단, 1 ≤ R, C ≤ 1000 이다. R은 미로 행의 개수, C는 열의 개수이다.
다음 입력으로 R줄동안 각각의 미로 행이 주어진다.
각각의 문자들은 다음을 뜻한다.
- #: 벽
- .: 지나갈 수 있는 공간
- J: 지훈이의 미로에서의 초기위치 (지나갈 수 있는 공간)
- F: 불이난 공간
J는 입력에서 하나만 주어진다.
출력
지훈이가 불이 도달하기 전에 미로를 탈출 할 수 없는경우 IMPOSSIBLE 을 출력한다.
지훈이가 미로를 탈출할 수 있는 경우에는 가장 빠른 탈출시간을 출력한다.
예제 입력 1
4 4 #### #JF# #..# #..#
예제 출력 1
3
풀이
http://melonicedlatte.com/2018/09/17/021623.html 에 올라가 있는 백준 사이트의 3055 탈출이라는 문제와 굉장히 유사합니다.
알고리즘은 bfs를 이용하면 풀 수 있는 문제입니다.
알고리즘을 모른다기보다는 시뮬레이션이라 구현이 다소 복잡한 문제였습니다.
저 같은 경우에는 map에는 초기 배치를 저장했습니다.
지훈이가 방문한 곳을 저장하는 jihoon_depth, 불이 방문한 곳을 저장하는 fire_depth 배열을 생성했습니다.
큐는 두 개를 사용하여 '불'과 '지훈' 에 대한 각 단계의 bfs 를 진행했습니다.
fire 큐에서 new_row와 new_col을 받은 다음에 인덱스 체크, 기존에 물이 차있었는지 여부, 비버 집인지, 돌인지를 체크합니다.
jihoon 큐에서는 new_row와 new_col 을 받은 다음에 직전 단계에서 물이 차있었으면 지훈이가 갈 수 없다고 판단하고 넘깁니다.
해당 구문을 통과하면 water 과 같이 조건 체크를 하고 , new_row와 new_col 이 out of index 라면 정답이 됩니다.
자세한 풀이는 소스코드를 참조해주세요~