반응형
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 | 31 |
Tags
- 비동기 처리
- 완전탐색
- IOS
- 초기화
- 프로그래머스
- 거리알고리즘
- 자료구조
- 앱아이콘 변경
- 싱글톤
- element tree
- 에러
- flutter
- dfs
- linebreak
- dart
- 플러터
- Render object tree
- 재귀
- Java
- 자바
- Widget Tree
- Singleton
- Lazy
- zwj
- 플러터 동작
- 알고리즘
- Kotlin
- 프리즈드
- 코틀린
- Android
Archives
- Today
- Total
모바일 개발하는 자바리안의 메모장
자바(JAVA) - 게임 맵 최단거리(Programmers : 1844) 본문
반응형
https://programmers.co.kr/learn/courses/30/lessons/1844
최단경로를 구해야하는 문제로, BFS알고리즘을 사용하여 풀 수 있었다.
딱히 꼬아놓은 내용이 없어서 어렵지 않게 풀 수 있었던 문제였다.
디버깅하며 예상한 방향으로 착하게 잘 움직이는 로봇을 보고 큰 희열을 느꼈던 문제
실행 순서는 다음과 같다 :
1. 방문을 체크하기 위한 배열, 거리를 계산해 줄 count 배열과 BFS 알고리즘을 수행할 Queue 구현
2. BFS 알고리즘을 수행할 While 문 구현 > Queue가 empty일 떄까지 반복
3. 4방향을 확인하며 Queue에 새로운 좌표 입력, visited, count 배열 업데이트
4. 목적지의 count 값 반환, 값이 0일 경우 도달할 방법이 없는 것을 의미하므로 -1 반환
<코드>
import java.util.*;
class Solution {
public int solution(int[][] maps) {
int N = maps.length;
int M = maps[0].length;
// 출바점으로부터의 거리를 측정하기 위한 count, 와 방문 여부 기록을 위한 visited
int[][] count = new int[N][M];
int[][] visited = new int[N][M];
// BFS 알고리즘을 위한 Queue
Queue<int[]> q = new LinkedList<int[]>();
// 시작점 입력, count 및 방문 처리
int[] temp = { 0, 0 };
q.add(temp);
count[0][0] = 1;
visited[0][0] = 1;
// Queue가 빌 때까지 4방향 확인하며 Count값 증가
while (!q.isEmpty()) {
int[] currNM = q.remove();
int currN = currNM[0];
int currM = currNM[1];
int currCount = count[currN][currM];
if (currN + 1 < N && visited[currN + 1][currM] == 0 && maps[currN + 1][currM] == 1) {
int[] t = new int[2];
t[0] = currN + 1;
t[1] = currM;
visited[t[0]][t[1]] = 1;
count[t[0]][t[1]] = currCount + 1;
q.offer(t);
}
if (currN - 1 >= 0 && visited[currN - 1][currM] == 0 && maps[currN - 1][currM] == 1) {
int[] t = new int[2];
t[0] = currN - 1;
t[1] = currM;
visited[t[0]][t[1]] = 1;
count[t[0]][t[1]] = currCount + 1;
q.offer(t);
}
if (currM + 1 < M && visited[currN][currM + 1] == 0 && maps[currN][currM + 1] == 1) {
int[] t = new int[2];
t[0] = currN;
t[1] = currM + 1;
visited[t[0]][t[1]] = 1;
count[t[0]][t[1]] = currCount + 1;
q.offer(t);
}
if (currM - 1 >= 0 &&visited[currN][currM - 1] == 0 && maps[currN][currM - 1] == 1) {
int[] t = new int[2];
t[0] = currN;
t[1] = currM - 1;
visited[t[0]][t[1]] = 1;
count[t[0]][t[1]] = currCount + 1;
q.offer(t);
}
}
// 도착점의 카운트 값이 0일 경우, 도달할 수 없음을 의미
return count[N-1][M-1] == 0 ? -1 : count[N-1][M-1];
}
}
반응형
'Java > Java.algorithm' 카테고리의 다른 글
자바(JAVA) - 크레인 인형뽑기 게임(Programmers : 64061) (0) | 2021.06.10 |
---|---|
자바(JAVA) - 타겟 넘버(Programmers : 43165) (0) | 2021.06.10 |
자바(JAVA) - 모두 0으로 만들기(Programmers : 76503) (0) | 2021.06.10 |
자바(JAVA) - 모의고사(Programmers : 42840) (0) | 2021.06.10 |
자바(JAVA) - 가장 큰 수(Programmers : 42746) (0) | 2021.06.10 |
Comments