https://www.acmicpc.net/problem/17070
그래프 탐색으로 접근한 문제다.
풀이
파이프의 앞쪽을 head, 뒤쪽을 tail로 설정하여 tail과 head의 x, y좌표를 비교하여 수평 이동해야 할지, 수직 이동해야 할지, 대각선 이동을 해야 할지 비교한 후 탐색을 통해 해결하였다.
파이프가 수평으로 놓인 경우
head의 x좌표와 tail의 y좌표가 맞는지 확인하면 된다. 동일하다면 파이프가 수평으로 놓인상태, 이경우에는 수평이동, 대각선 이동이 가능하다.
파이프가 수직으로 놓인 경우
head의 x좌표와 tail의 x좌표가 다르고 y좌표가 서로 다르다면 수직으로 놓인 경우다. 이경우에는 수직이동, 대각선이동이 가능하다.
파이프가 대각선으로 놓인 경우
당연하게도 head와 tail의 x좌표 y좌표가 모두 다른경우다. 이경우에는 3가지 이동을 모두 수행하면 된다.
이동을 수행할 때에는 이동할 좌표가 유효한 범위인지, 그리고 벽이 아닌 빈 공간인지를 확인하고 탐색 큐에 담아주었다.
정답 코드
'Problem Solving > BOJ' 카테고리의 다른 글
[2580] 스도쿠 (1) | 2022.12.07 |
---|---|
[11559] Puyo Puyo (0) | 2022.12.05 |
[12851] 숨바꼭질 2 (0) | 2022.11.30 |
[2096] 내려가기 (0) | 2022.11.29 |
[3649] 로봇 프로젝트 (0) | 2022.11.26 |