인프런 커뮤니티 질문&답변
혹시 sum + arr[L + 1]로 해도 될까요?
작성
·
174
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 === 1) return;
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에 누적하지 않는다를 적용하는 재귀함수입니다.





