Computer >> 컴퓨터 >  >> 프로그램 작성 >> JavaScript

JavaScript에서 자릿수 합을 기준으로 숫자 정렬

<시간/>

문제

첫 번째이자 유일한 인수로 양의 정수 배열인 arr을 취하는 JavaScript 함수를 작성해야 합니다.

우리 함수는 가장 높은 자릿수 합을 가진 숫자가 먼저 오고 더 작은 자릿수 합을 가진 숫자가 오는 방식으로 입력 배열을 정렬해야 합니다.

예를 들어, 함수에 대한 입력이 -

인 경우

입력

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 ]