230722 공원 산책

Jongleee·2023년 7월 22일
0

TIL

목록 보기
318/576
public int[] solution(String[] park, String[] routes) {
	int sx = 0;
	int sy = 0;

	char[][] arr = new char[park.length][park[0].length()];

	for (int i = 0; i < park.length; i++) {
		arr[i] = park[i].toCharArray();

		if (park[i].contains("S")) {
			sy = i;
			sx = park[i].indexOf("S");
		}
	}

	for (String st : routes) {
		String way = st.split(" ")[0];
		int len = Integer.parseInt(st.split(" ")[1]);

		int nx = sx;
		int ny = sy;

		for (int i = 0; i < len; i++) {
			switch (way) {
				case "E":
					nx++;
					break;
				case "W":
					nx--;
					break;
				case "S":
					ny++;
					break;
				case "N":
					ny--;
					break;
			}
			if (nx < 0 || ny < 0 || ny >= arr.length || nx >= arr[0].length || arr[ny][nx] == 'X') {
				break;
			}
			if (i == len - 1) {
				sx = nx;
				sy = ny;
			}
		}
	}

	return new int[] { sy, sx };
}

출처:https://school.programmers.co.kr/learn/courses/30/lessons/172928

0개의 댓글