在 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 ]