GitHub ID : soohyun-dev
윤수현의 개발 공간
GitHub ID : soohyun-dev
전체 방문자
오늘
어제
  • 분류 전체보기 (918)
    • 성장기록 (49)
      • 성장기록 (3)
      • 우아한테크코스 (16)
      • 프로젝트 (15)
      • TIL (14)
      • 테오의 스프린트 (1)
    • 프로그래밍언어 (88)
      • C언어 (14)
      • HTML\CSS (12)
      • JavaScript (7)
      • React (23)
      • Python (11)
      • JAVA (14)
      • TypeScript (6)
    • 알고리즘 공부 (736)
      • 코드업 - 파이썬 (108)
      • 백준 - 파이썬 (468)
      • 백준 - 자바스크립트 (125)
      • 프로그래머스 - 파이썬 (1)
      • 프로그래머스 - 자바스크립트 (34)
    • 책 리뷰 (9)
      • 프로그래밍 (3)
      • 독서 (6)
    • 전자기기 (1)
    • 일상, 일기 (18)
    • 기술 세미나 (2)

블로그 메뉴

  • 홈
  • 태그
  • 방명록

공지사항

인기 글

태그

  • 백준파이썬
  • 프로그래밍언어
  • 코드업
  • 프론트엔드
  • 백준
  • 영어
  • 코딩
  • 자바스크립트
  • 영어독해
  • 프로그래머스자바스크립트
  • 코테
  • 프로그래머스
  • PYTHON
  • 백준풀이
  • 프로그래머스풀이
  • 코딩테스트
  • 파이썬
  • javascript
  • 독해
  • 코드업파이썬

최근 댓글

최근 글

티스토리

hELLO · Designed By 정상우.
GitHub ID : soohyun-dev

윤수현의 개발 공간

프로그래머스 / Level 2 , 깊이/너비 우선 탐색(DFS/BFS) , 게임 맵 최단거리 자바스크립트 , JS
알고리즘 공부/프로그래머스 - 자바스크립트

프로그래머스 / Level 2 , 깊이/너비 우선 탐색(DFS/BFS) , 게임 맵 최단거리 자바스크립트 , JS

2022. 9. 22. 23:54

프로그래머스 / Level 2 , 깊이/너비 우선 탐색(DFS/BFS) , 게임 맵 최단거리 자바스크립트 , JS

 

 

 

 

문제 출처

https://school.programmers.co.kr/learn/courses/30/lessons/1844#qna

 

프로그래머스

코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.

programmers.co.kr

 

 

 

 

 

 

 

 

 

정답

 

 

1) visited  최초 방문 처리로 풀기 

function solution(maps) {
  let answer = 0;
  let [N, M] = [maps.length, maps[0].length];
  let dr = [
    [0, 1],
    [1, 0],
    [-1, 0],
    [0, -1],
  ];
  let dq = [[1, 0, 0]];
  let visited = Array.from(Array(N), () => Array(M).fill(false));
  visited[0][0] = true;
  while (dq.length !== 0) {
    let [Z, X, Y] = dq[0];
    dq = dq.splice(1);
    for (let i of dr) {
      let [mx, my] = [X + i[0], Y + i[1]];
      if (mx >= N || mx < 0 || my >= M || my < 0) continue;
      else {
        if (!visited[mx][my] && maps[mx][my] === 1) {
          dq.push([Z + 1, mx, my]);
          visited[mx][my] = true;
          if (mx === N - 1 && my === M - 1) {
            answer = Z + 1;
            break;
          }
        }
      }
    }
  }
  return answer !== 0 ? answer : -1;
}

 

 

 

 

2) dist 최소 거리 찾으면서 풀기

 

function solution(maps) {
  let [N, M] = [maps.length, maps[0].length];
  let dr = [
    [0, 1],
    [1, 0],
    [-1, 0],
    [0, -1],
  ];
  let dq = [[0, 0]];
  let dist = Array.from(Array(N), () => Array(M).fill(Infinity));
  dist[0][0] = 1;
  while (dq.length !== 0) {
    let [X, Y] = dq[0];
    dq = dq.splice(1);
    for (let i of dr) {
      let [mx, my] = [X + i[0], Y + i[1]];
      if (mx >= N || mx < 0 || my >= M || my < 0) continue;
      else {
        if (dist[mx][my] > dist[X][Y] + 1 && maps[mx][my] === 1) {
          dq.push([mx, my]);
          dist[mx][my] = dist[X][Y] + 1;
        }
      }
    }
  }
  return dist[N - 1][M - 1] !== Infinity ? dist[N - 1][M - 1] : -1;
}

 

 

 

 

반응형

'알고리즘 공부 > 프로그래머스 - 자바스크립트' 카테고리의 다른 글

프로그래머스 / Level 2 , 월간 코드 챌린지 시즌3 , n^2 배열 자르기 자바스크립트 , JS  (2) 2022.09.23
프로그래머스 / Level 2 , 연습문제 , 멀리 뛰기 자바스크립트 , JS  (0) 2022.09.23
프로그래머스 / Level 2 , 2018 KAKAO BLIND RECRUITMENT , [1차] 캐시 자바스크립트 , JS  (0) 2022.09.22
프로그래머스 / Level 2 , 월간 코드 챌린지 시즌2 , 괄호 회전하기 자바스크립트 , JS  (1) 2022.09.22
프로그래머스 / Level 2 , 정렬 , H-Index 자바스크립트 , JS  (0) 2022.09.22
    '알고리즘 공부/프로그래머스 - 자바스크립트' 카테고리의 다른 글
    • 프로그래머스 / Level 2 , 월간 코드 챌린지 시즌3 , n^2 배열 자르기 자바스크립트 , JS
    • 프로그래머스 / Level 2 , 연습문제 , 멀리 뛰기 자바스크립트 , JS
    • 프로그래머스 / Level 2 , 2018 KAKAO BLIND RECRUITMENT , [1차] 캐시 자바스크립트 , JS
    • 프로그래머스 / Level 2 , 월간 코드 챌린지 시즌2 , 괄호 회전하기 자바스크립트 , JS
    GitHub ID : soohyun-dev
    GitHub ID : soohyun-dev
    환영합니다!😊 이곳은 저의 개발에 관한 내용들을 정리하는 공간입니다. 알고리즘 풀이에도 관심이 많아요. 좋은 하루 되세요~! github : soohyun_dev

    티스토리툴바