인프런 커뮤니티 질문&답변

highJoon님의 프로필 이미지
highJoon

작성한 질문수

자바스크립트 알고리즘 문제풀이 입문(코딩테스트 대비)

5. 합이 같은 부분집합(이진트리 DFS)

혹시 sum + arr[L + 1]로 해도 될까요?

작성

·

134

0

<html>

<head>
    <meta charset="UTF-8">
    <title>5. 합이 같은 부분집합</title>
</head>

<body>
    <script>
        function solution(arr) {
            let answer = 'NO', total = arr.reduce((a, b) => a + b, 0), sum = 0, n = arr.length, flag = 0;
            function DFS(L, sum) {
                if (flag === 1return;
                if (L === n{
                    if ((total - sum=== sum{
                        answer = 'YES';
                        flag = 1;
                    }
                }
                else {
                    DFS(L + 1, sum + arr[L + 1]);
                    DFS(L + 1, sum);
                }
            }
            DFS(0, 0);
            return answer;
        }

        let arr = [1, 3, 5, 6, 7, 10];
        console.log(solution(arr));
    </script>
</body>

</html>
먼저 풀어봤을때 제가 이해했던 바로는 sum+arr[L+1]로 생각하고 풀었는데, 답은 YES가 나왔습니다. 해설강의에서는 sum+arr[L]로 하셔서 궁금해서 질문드립니다.

답변 1

0

김태원님의 프로필 이미지
김태원
지식공유자

안녕하세요^^

위에 코드처럼 하면 arr[0] 값은 재귀에서 sum에 더한다, 더하지 않는다를 적용 하지 않습니다.

위에 코드는 arr[1]값부터 sum에 누적한다, sum에 누적하지 않는다를 적용하는 재귀함수입니다.

highJoon님의 프로필 이미지
highJoon

작성한 질문수

질문하기