정수 배열을 취하는 JavaScript 함수를 작성해야 합니다. 우리의 함수는 최대 합을 가진 인접하지 않은 요소의 하위 집합을 찾는 데 필요합니다.
마지막으로 함수는 해당 부분 집합의 합계를 계산하고 반환해야 합니다.
예를 들어 -
입력 배열이 -
인 경우const arr = [3, 5, 7, 8, 10];
그러면 숫자의 인접하지 않은 부분 집합이 3, 7, 10이 되므로 출력은 20이 되어야 합니다.
예시
이에 대한 코드는 -
const arr = [3, 5, 7, 8, 10]; const maxSubsetSum = (arr = []) => { let min = −Infinity const helper = (arr, ind) => { if ( ind < 0 ){ return min }; let inc = helper(arr, ind−2); let notInc = helper(arr, ind−1); inc = inc == min ? arr[ind] : Math.max(arr[ind], arr[ind] + inc); return Math.max( inc, notInc ); }; return helper(arr, arr.length − 1); }; console.log(maxSubsetSum(arr));
출력
콘솔의 출력은 -
20