반응형
문제
SW Expert Academy
SW 프로그래밍 역량 강화에 도움이 되는 다양한 학습 컨텐츠를 확인하세요!
swexpertacademy.com
아이디어
입구부터 찾는게 아닌 출구부터 찾아 올라가는 방식으로 풀이했다.
코드
import java.io.*;
import java.util.*;
public class Solution {
public static void main(String[] args) throws Exception {
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
StringTokenizer st;
// 사다리를 저장할 배열
int[][] Ladder = new int[100][100];
// 방문 체크 배열
boolean[][] check = new boolean[100][100];
// 테스트 케이스 10번
for (int tc = 0; tc < 10; ++tc) {
// 테스트 케이스 번호 입력
int T = Integer.parseInt(br.readLine());
// 사다리 배열 입력
for (int i = 0; i < 100; ++i) {
st = new StringTokenizer(br.readLine(), " ");
for (int j = 0; j < 100; ++j) {
Ladder[i][j] = Integer.parseInt(st.nextToken());
check[i][j] = false;
}
}
// 도착 지점 탐색
int exitY = 0;
int exitX = 99;
for (int j = 0; j < 100; ++j) {
if (Ladder[exitX][j] == 2) {
exitY = j;
break;
}
}
// 경로 탐색
int dir = 1;// 1 상 2 하(사용안됌) 3 좌 4 우 - default 상
while (true) {
check[exitX][exitY] = true;
dir = 1;
// 좌측 검사
if (exitY - 1 >= 0 ) {
if (Ladder[exitX][exitY - 1] == 1 && check[exitX][exitY - 1] == false) {
dir = 3;
}
}
if(exitY+1 < 100) {
// 우측검사
if (Ladder[exitX][exitY + 1] == 1 && check[exitX][exitY + 1] == false) {
dir = 4;
}
}
switch (dir) {
case 1:// 상
if (check[exitX - 1][exitY] == false && (exitX - 1) >= 0)
exitX--;
break;
case 3:// 좌
if (check[exitX][exitY - 1] == false && (exitY - 1) >= 0)
exitY--;
break;
case 4:// 우
if (check[exitX][exitY + 1] == false && (exitY + 1) < 100)
exitY++;
break;
}
if (exitX <= 0) break;
}
System.out.println("#" + T + " " + exitY);
}
}
}
cpdm
choppadontbiteme.tistory.com
반응형
'Algorithm > SWEA' 카테고리의 다른 글
[ SWEA ] 1218 괄호짝짓기 D4 JAVA (0) | 2022.09.29 |
---|---|
[ SWEA ] 1861 정사각형 방 D4 JAVA (0) | 2022.09.29 |
[ SWEA ] 1223. 계산기 2 D4 JAVA (0) | 2022.09.29 |
[ SWEA ] 10726. 이진수 표현 D3 C++ (0) | 2022.09.06 |
[ SWEA ] 1221. GNS D3 C++ (0) | 2022.08.30 |