250x250
Notice
Recent Posts
Recent Comments
Link
반응형
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | |||||
3 | 4 | 5 | 6 | 7 | 8 | 9 |
10 | 11 | 12 | 13 | 14 | 15 | 16 |
17 | 18 | 19 | 20 | 21 | 22 | 23 |
24 | 25 | 26 | 27 | 28 | 29 | 30 |
Tags
- dfs
- string
- 큐
- alter
- Union-find
- javascript
- priority_queue
- spring boot
- union_find
- Java
- CSS
- JPA
- 리소스모니터링
- date
- Properties
- scanner
- set
- 힙덤프
- List
- deque
- 스프링부트
- map
- 스택
- NIO
- BFS
- sql
- html
- Calendar
- GC로그수집
- math
Archives
- Today
- Total
매일 조금씩
프로그래머스 level1 : 공원 산책 - Java 본문
728x90
반응형
import java.util.*;
import java.lang.*;
class Solution {
public int[] solution(String[] park, String[] routes) {
int[] answer = new int[2];
int[] now = new int[2];
Map<String, int[]> route = new HashMap<>();
int[] N = {-1,0};
int[] S = {1, 0};
int[] W = {0, -1};
int[] E = {0, 1};
route.put("N", N);
route.put("S", S);
route.put("W", W);
route.put("E", E);
// 시작위치 now로 set하기
for(int i=0; i<park.length; i++){
for(int j = 0; j<park[0].length(); j++){
if(park[i].charAt(j) == 'S'){
now[0] = i;
now[1] = j;
}
}
}
// routes 돌기
for(int i=0; i<routes.length; i++){
String way = routes[i].split(" ")[0];
int count = Integer.parseInt(routes[i].split(" ")[1]);
boolean flag = false;
int[] step = route.get(way);
int[] move = new int[2];
move[0] = now[0];
move[1] = now[1];
// park 넘어가는지 체크
if(now[0] + step[0]*count >= park.length || now[0] + step[0]*count < 0
|| now[1] + step[1]*count >= park[0].length() || now[1] + step[1]*count < 0){
flag = true;
}else {
// X 만나는지 체크
for(int k = 1; k<=count; k++){
if(park[move[0] + step[0]].charAt(move[1] + step[1]) == 'X'){
flag = true;
break;
}
move[0] += step[0];
move[1] += step[1];
}
}
if(!flag){
now[0] = move[0];
now[1] = move[1];
}
}
answer[0] = now[0];
answer[1] = now[1];
return answer;
}
}
728x90
반응형
'알고리즘' 카테고리의 다른 글
프로그래머스 level1 : 덧칠하기 - Java (0) | 2023.06.02 |
---|---|
프로그래머스 level1 : 바탕화면 정리 - Java (0) | 2023.06.02 |
프로그래머스 level1 : 추억 점수 - Java (0) | 2023.06.02 |
프로그래머스 level1 : 달리기 경주 - Java (0) | 2023.06.02 |
프로그래머스 level1 : 대충 만든 자판 - JAVA (0) | 2023.06.01 |