[프로그래머스] 양과 늑대 - JavaScript

이수동·2022년 3월 23일
1
post-thumbnail
post-custom-banner

프로그래머스 Level 3 - 양과 늑대


📌 문제 설명


📌 생각한 풀이 방법

  1. connectedNode에 연결된 노드를 인덱스에 맞게 push한다.
  2. DFS를 사용해 모든 경로를 탐색한다.
  3. sheep의 수를 매 경우마다 answer와 비교하여 최대 값을 저장한다.
  4. 양의 수인 sheep과 wolf의 수가 같은 경우는 return한다.
  5. connectedNode에 현재 노드에서 이동 가능한 노드를 newPossibles에 추가한다.
  6. 모든 경로를 탐색후 최대 값인 answer를 반환한다.

📌 풀이

function solution(info, edges) {
  let answer = 0;
  let connectedNode = Array.from({ length: info.length }, () => []);

  for (let i = 0; i < edges.length; i++) {
    let current = edges[i];
    connectedNode[current[0]].push(current[1]); // connectedNode에 연결된 노드를 인덱스에 맞게 push
  }

  function dfs(currentNode, sheep, wolf, possible) {
    let newPossibles = [...possible];
    let currentIndex = newPossibles.indexOf(currentNode);

    if (info[currentNode]) {
      wolf++;
    } else {
      sheep++;
    }

    answer = Math.max(answer, sheep); // sheep의 수를 매 경우마다 answer와 비교하여 최대 값을 저장

    if (sheep === wolf) {
      // 양의 수인 sheep과 wolf의 수가 같은 경우
      return;
    }

    newPossibles.push(...connectedNode[currentNode]);
    // connectedNode에 현재 노드에서 이동 가능한 노드를 newPossibles에 추가
    newPossibles.splice(currentIndex, 1);

    for (const nextNode of newPossibles) {
      dfs(nextNode, sheep, wolf, newPossibles);
    }
  }

  dfs(0, 0, 0, [0]); // DFS를 사용해 모든 경로를 탐색

  return answer; // 모든 경로를 탐색후 최대 값인 answer를 반환
}
profile
기록을 통한 성장하기 🧐
post-custom-banner

0개의 댓글