Algorithm/SWEA
[ SWEA ] 1210. Ladder1 D4 (JAVA)
_cpdm_
2021. 8. 8. 12:41
반응형
SW Expert Academy
SW 프로그래밍 역량 강화에 도움이 되는 다양한 학습 컨텐츠를 확인하세요!
swexpertacademy.com
문제 이해 |
- 김 대리가 사다리타기를 그리는데 어떤 시작점에서 출발해야 X 표시가 나오는지 알고싶어한다.
- X 표시로 나오게 되는 시작점을 찾자.
아이디어 |
- 시작 부터 출구를 찾는다.
- 출구에서 입구로 올라가며 찾는다.
코드 |
import java.io.*;
import java.util.*;
public class Solution {
public static void main(String[] args) throws Exception {
// IO
// System.setIn(new FileInputStream("res/Input_d4_2일차Ladder1.txt"));
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
반응형