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

 

반응형