在 JavaScript 中进行转换后找到最小的总和
问题
我们需要编写一个JavaScript函数,它接受一个正整数数组。我们可以根据需要多次对它们运行以下操作来转换其元素-
if arr[i] > arr[j] then arr[i] = arr[i] - arr[j]
当没有更多的转换是可能的,我们的函数应该返回它的总和。
示例
以下是代码-
const arr = [6, 9, 21];
const smallestSum = (arr = []) => {
const equalNums = arr => arr.reduce((a, b) => {
return (a === b) ? a : NaN;
});
if(equalNums(arr)){
return arr.reduce((a, b) => {
return a + b;
});
}else{
const sorted = arr.sort((a, b) => {
return a-b;
});
const last = sorted[arr.length-1] - sorted[0]
sorted.pop();
sorted.push(last);
return smallestSum(sorted);
};
};
console.log(smallestSum(arr));输出结果以下是控制台输出-
9
热门推荐
10 香港老妈结婚祝福语简短
11 毕业立体贺卡祝福语简短
12 简短新年年会祝福语
13 评论小品祝福语大全简短
14 恭喜师兄结婚祝福语简短
15 员工集体辞职祝福语简短
16 高中新生祝福语 简短
17 装修祝福语男生搞笑简短
18 生日开业蛋糕祝福语简短