在 JavaScript 中根据数字总和对数字进行排序

问题

我们需要编写一个 JavaScript 函数,它接受一个正整数数组 arr 作为第一个也是唯一的参数。

我们的函数应该以这样一种方式对输入数组进行排序,即具有最高数字和的数字首先出现,然后是具有较小数字和的数字。

例如,如果函数的输入是 -

输入

const arr = [5, 34, 1, 13, 76, 8, 78, 101, 57, 565];

输出

const output = [565, 78, 76, 57, 8, 34, 5, 13, 101, 1];

输出说明

因为565的最大数位和为16,其次是78和76,101和1的最小数位和分别为2和1

示例

以下是代码 -

const arr = [5, 34, 1, 13, 76, 8, 78, 101, 57, 565];
const addDigits = (num, sum = 0) => {
   if(num){
      return addDigits(Math.floor(num / 10), sum + (num % 10));
   };
   return sum;
};
const sortByDigitSum = (arr = []) => {
   arr.sort((a, b) => {
      return addDigits(b) - addDigits(a);
   });
   return arr;
};
sortByDigitSum(arr);
console.log(arr);
输出结果
[ 565, 78, 76, 57, 8, 34, 5, 13, 101, 1 ]