본문 바로가기

Algorithm/SWEA

[ SWEA ] SWEA 1210 Ladder 1 D4 JAVA

반응형


문제

 

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