출처 : https://www.acmicpc.net/problem/5427
불 성공
시간 제한 | 메모리 제한 | 제출 | 정답 | 맞은 사람 | 정답 비율 |
---|---|---|---|---|---|
1 초 | 128 MB | 7260 | 1665 | 982 | 21.064% |
문제
상근이는 빈 공간과 벽으로 이루어진 건물에 갇혀있다. 건물의 일부에는 불이 났고, 상근이는 출구를 향해 뛰고 있다.
매 초마다, 불은 동서남북 방향으로 인접한 빈 공간으로 퍼져나간다. 벽에는 불이 붙지 않는다. 상근이는 동서남북 인접한 칸으로 이동할 수 있으며, 1초가 걸린다. 상근이는 벽을 통과할 수 없고, 불이 옮겨진 칸 또는 이제 불이 붙으려는 칸으로 이동할 수 없다. 상근이가 있는 칸에 불이 옮겨옴과 동시에 다른 칸으로 이동할 수 있다.
빌딩의 지도가 주어졌을 때, 얼마나 빨리 빌딩을 탈출할 수 있는지 구하는 프로그램을 작성하시오.
입력
첫째 줄에 테스트 케이스의 개수가 주어진다. 테스트 케이스는 최대 100개이다.
각 테스트 케이스의 첫째 줄에는 빌딩 지도의 너비와 높이 w와 h가 주어진다. (1 ≤ w,h ≤ 1000)
다음 h개 줄에는 w개의 문자, 빌딩의 지도가 주어진다.
- '.': 빈 공간
- '#': 벽
- '@': 상근이의 시작 위치
- '*': 불
각 지도에 @의 개수는 하나이다.
출력
각 테스트 케이스마다 빌딩을 탈출하는데 가장 빠른 시간을 출력한다. 빌딩을 탈출할 수 없는 경우에는 "IMPOSSIBLE"을 출력한다.
예제 입력 1
5 4 3 #### #*@. #### 7 6 ###.### #*#.#*# #.....# #.....# #..@..# ####### 7 4 ###.### #....*# #@....# .###### 5 5 ..... .***. .*@*. .***. ..... 3 3 ### #@# ###
예제 출력 1
2 5 IMPOSSIBLE IMPOSSIBLE IMPOSSIBLE
출처
ACM-ICPC > Regionals > Europe > Northwestern European Regional Contest > Benelux Algorithm Programming Contest > BAPC 2012 F번
풀이
http://melonicedlatte.com/2018/09/17/023544.html 풀이와 굉장히 유사합니다.
문제는 거의 동일하고, 테스트 케이스만 조금 늘어난 문제 형태입니다.
알고리즘은 bfs를 이용하면 풀 수 있는 문제입니다.
알고리즘을 모른다기보다는 시뮬레이션이라 구현이 다소 복잡한 문제였습니다.
저 같은 경우에는 map에는 초기 배치를 저장했습니다.
상근이가 방문한 곳을 저장하는 sanggeun_depth, 불이 방문한 곳을 저장하는 fire_depth 배열을 생성했습니다.
큐는 두 개를 사용하여 '불'과 '상근' 에 대한 각 단계의 bfs 를 진행했습니다.
fire 큐에서 new_row와 new_col을 받은 다음에 인덱스 체크, 기존에 물이 차있었는지 여부, 비버 집인지, 돌인지를 체크합니다.
상근 큐에서는 new_row와 new_col 을 받은 다음에 직전 단계에서 물이 차있었으면 상근이가 갈 수 없다고 판단하고 넘깁니다.
해당 구문을 통과하면 water 과 같이 조건 체크를 하고, new_row와 new_col 이 out of index 라면 정답이 됩니다.
자세한 풀이는 소스코드를 참조해주세요~