728x90
⬛ 1210. [S/W 문제해결 기본] 2일차 - Ladder1 - java
https://swexpertacademy.com/main/code/problem/problemDetail.do?contestProbId=AV14ABYKADACFAYh
⬛ 풀이 방법
- 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 |