문제
숫자를 받아서 그 제수의 개수를 반환하는 JavaScript 함수를 작성해야 합니다.
입력
const num = 30;
출력
const output = 8;
제수는 -
이기 때문에1, 2, 3, 5, 6, 10, 15, 30
예시
다음은 코드입니다 -
const num = 30; const countDivisors = (num = 1) => { if (num === 1) return num let divArr = [[2, 0]] let div = divArr[0][0] while (num > 1) { if (num % div === 0) { for (let i = 0; divArr.length; i++) { if (divArr[i][0] === div) { divArr[i][1] += 1 break } else { if (i === divArr.length - 1) { divArr.push([div, 1]) break } } } num /= div } else { div += 1 } } for (let i = 0; i < divArr.length; i++) { num *= divArr[i][1] + 1 } return num } console.log(countDivisors(num));
출력
8