我们需要编写一个JavaScript函数,该函数可以包含任意数量的参数(均为Number类型)。
该函数应计算所有可能的加法和减法之和。
例如-如果参数是1,2,3
那么所有可能的组合是-
1 + 2 + 3 1 - 2 - 3 1 + 2 - 3 1 - 2 + 3
最后,该函数的总和应最接近0。在这种情况下,该答案将仅为0。
const findSmallestPositive = (...arr) => {
let set = new Set([Math.abs(arr[0])]);
for (let i = 1;
i < arr.length; i++){
const secondSet = new Set;
for (let d of Array.from(set)){
secondSet.add(Math.abs(d + arr[i]))
secondSet.add(Math.abs(d - arr[i]))
};
set = secondSet;
};
return Math.min(...Array.from(set))
};
console.log(findSmallestPositive(5,3))
console.log(findSmallestPositive(1,2,3))
console.log(findSmallestPositive(1,2,3,5))输出结果
这将产生以下输出-
2 0 1