본문 바로가기

공부의 기록/SWEA

[SWEA] 1210. [S/W 문제해결 기본] 2일차 - Ladder1 - java

728x90

 1210. [S/W 문제해결 기본] 2일차 - Ladder1 - java

https://swexpertacademy.com/main/code/problem/problemDetail.do?contestProbId=AV14ABYKADACFAYh 

 

SW Expert Academy

SW 프로그래밍 역량 강화에 도움이 되는 다양한 학습 컨텐츠를 확인하세요!

swexpertacademy.com

 풀이 방법

  • 0으로 채워진 평면상에 사다리는 연속된 1로 표현되고, 도착 지점은 2로 표현된다. -> 2에서부터 거꾸로 올라가는 방법을 사용
  • 현재 위치에서 왼쪽 또는 오른쪽에 1로 채워진 곳이 있다면 왼쪽 또는 오른쪽으로 이동
  • 현재 위치에서 왼쪽 또는 오른쪽에 1로 채워진 곳이 없다면 위로 이동
  • 맨 위에 도착할 때까지 반복한 후 도착했을 때의 j를 출력

 소스 코드

import java.util.Scanner;

public class Ladder1_1210 {
	static int[][] data = new int[100][100];
	static int X = -1;
	static int destY;
	public static void main(String[] args) {

		Scanner sc = new Scanner(System.in);
		StringBuilder sb = new StringBuilder();
		
		for (int tc = 1; tc <= 10; tc++) {
			int T = sc.nextInt();
			for(int i = 0; i < 100; i++) {
				for(int j = 0; j < 100; j++) {
					data[i][j] = sc.nextInt();
					if(data[i][j] == 2) {
						destY = j;			//2의 위치를 저장
					}
				}
			}
			ladder(99,destY);				//2의 위치부터 시작
			sb.append("#" + tc + " " + X + "\n");
		}
		System.out.println(sb.toString());
	}
	public static void ladder(int i, int j) {
		while(i > 0) {			//맨 꼭대기로 올라올때까지
			if(j-1 >=0 && (data[i][j-1] == 1)) {		//왼쪽으로 이동
				while(j-1 >=0 && (data[i][j-1] == 1)) {		//왼쪽에 1이 있을 때까지 이동
					j = j-1;
				}
				i = i-1;				//한칸 올라가주지 않으면 무한 루프가 발생하므로 한칸 위로 올라가기
			}else if(j+1 < 100 && (data[i][j+1] == 1)) {		//오른쪽으로 이동
				while(j+1 < 100 && (data[i][j+1] == 1)) {		//오른쪽에 1이 있을때까지 이동
					j = j+1;
				}
				i = i-1;			//한칸 올라가주지 않으면 무한 루프가 발생하므로 한칸 위로 올라가기
			}else {
				i = i-1;			//왼쪽, 오른쪽으로 이동할 수 없을 때 위로 올라가기
			}
		}	
		X = j;					//2를 타고 올라간 위치를 저장
	}

}
728x90

'공부의 기록 > SWEA' 카테고리의 다른 글

[SWEA] 1954. 달팽이 숫자 - java  (0) 2022.02.08
[SWEA] 1289. 원재의 메모리 복구하기 - java  (0) 2022.02.04