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
- Lv. 1
- LEVEL 2
- select
- Lv. 0
- 프로그래머스
- 자바스크립트
- Java
- 너비 우선 탐색
- programmers
- join
- 동적계획법
- level 3
- Lv. 3
- Dynamic Programming
- 티스토리챌린지
- softeer
- SQL 고득점 KIT
- bfs
- C언어
- 파이썬
- SQL
- dfs
- Lv. 2
- javascript
- group by
- 오블완
- 깊이 우선 탐색
- DP
- Python
- 소프티어
Archives
- Today
- Total
몸과 마음이 건전한 SW 개발자
프로그래머스 [Lv. 3] 경주로 건설 {언어 : JavaScript} [다시 풀어 보기] 본문
문제 링크
https://school.programmers.co.kr/learn/courses/30/lessons/67259
정답 코드
function solution(board) {
const n = board.length;
const [er, ec] = [n-1, n-1];
const maxCosts = 25 * 25 * 500 + 1;
let visited = Array(n).fill().map(() => Array(n).fill().map(() => Array(4).fill().map(() => maxCosts)));
const dr = [-1, 1, 0, 0];
const dc = [0, 0, -1, 1];
const isValid = (nr, nc) => {
return 0 <= nr && nr < n && 0 <= nc && nc < n;
};
// 방향, 금액, r, c
// 아래로 시작, 오른쪽으로 시작
let q = [[1, 0, 0, 0], [3, 0, 0, 0]]
while (q.length) {
const [direction, cost, r, c] = q.shift();
for (let d = 0; d < 4; d++) {
const nr = r + dr[d];
const nc = c + dc[d];
if (isValid(nr, nc) && board[nr][nc] == 0) {
const newCosts = cost + (direction == d ? 100 : 600);
if (newCosts < visited[nr][nc][direction]) {
visited[nr][nc][direction] = newCosts;
q.push([d, newCosts, nr, nc]);
};
};
};
q.sort(([a, b, c, d], [e, f, g, h]) => b - f);
};
const answer = Math.min(...visited[er][ec]);
return answer;
}
풀이 방법
- n * n * 4인 3차원 배열을 만든다.
- 비용이 작은 길이를 찾기 위해 maxCost 값으로 채운다.
- 적당히 큰 크기로 n이 25가 최대이기 때문에 25 * 25에 500을 곱하고 1을 더했다.
- 더 정확하려면 25 * 25 * 600 + 1이 맞을 것 같다.
- 시작 지점은 0,0이며 방향을 아래, 오른쪽으로 설정했다. (당연한 얘기다)
- 현재 지점에서 다음 지점으로 이동할 때 방향이 바뀌면 코너가 생기므로 600을 더한다.
- 아닌 경우는 100을 더한다.
- 여기서 600을 더하는 이유는 직선 도로 하나 + 코너 하나가 생기기 때문이다.
- 4방향 탐색이 끝나면 q를 정렬한다.
- 람다식을 사용해서 현재 든 비용을 기준으로 오름차순 정렬한다.
- 가장 적게 든 비용부터 움직이기 위함이다.
- 이후 도착지점의 배열에서 최값을 구한 뒤 answer에 대입하면 끝!
느낀점
- 사실 이 문제는 heapq로 푸는게 정배?인데 굳이 없어도 풀린다.
- bfs라고 했지만 dp에 가까운 것 같기도 하다.
- 요즘 다시 풀어 봐야 하는 문제들이 많아진다.
- 한 번 복습할 필요가 있다.
'알고리즘 > 다시 풀어 보기' 카테고리의 다른 글
프로그래머스 [Lv. 3] 풍선 터트리기 {언어 : Java} [다시 풀어 보기] (0) | 2024.07.02 |
---|---|
프로그래머스 [Lv. 3] [1차] 셔틀버스 {언어 : Python} [다시 풀어 보기] (0) | 2024.06.28 |
프로그래머스 [Lv. 3] 디스크 컨트롤러 {언어 : Python} [다시 풀어 보기] (0) | 2024.06.20 |
프로그래머스 [Lv. 3] 섬 연결하기 {언어 : Python} [프림 알고리즘, 다시 풀어 보기] (0) | 2024.06.16 |
프로그래머스 [Lv. 3] 양과 늑대 {언어 : Python} [다시 풀어 보기] (0) | 2024.05.27 |