#1. 하샤드 수
문제 설명
양의 정수 x가 하샤드 수이려면 x의 자릿수의 합으로 x가 나누어져야 합니다. 예를 들어 18의 자릿수 합은 1+8=9이고, 18은 9로 나누어 떨어지므로 18은 하샤드 수입니다. 자연수 x를 입력받아 x가 하샤드 수인지 아닌지 검사하는 함수, solution을 완성해주세요.
제한조건
- x는 1 이상, 10000 이하인 정수입니다.
입출력 예
arr | return |
10 | true |
20 | true |
11 | false |
13 | false |
풀이
function solution(x) {
// 파라미터 값을 문자열로 바꾼 후 배열에 담고, map 함수로 숫자형으로 바꾼 뒤 reduce 함수로 더하였다.
const answer = x.toString().split('').map(v => parseInt(v)).reduce((a,b) => a + b);
// 삼항연산자를 통해 파라미터 값에서 위에서 나온 값을 나누었을 때 0이 되면 true, 그렇지 않으면 false 리턴
return x % answer === 0 ? true : false;
}
// 호출
solution(12);
solution(11);
결과
소감
메서드 체인을 활용해서 풀어보았는데, 풀기에는 편했지만 가독성은 떨어진다는 단점이 있어 보입니다.
'Algorithm > programmers' 카테고리의 다른 글
[Algorithm] JavaScript, Level1. 콜라츠 추측 (0) | 2022.06.25 |
---|---|
[Algorithm] JavaScript, Level1. 평균구하기 (0) | 2022.06.25 |
[Algorithm] JavaScript, Level1. 핸드폰 번호 가리기 (0) | 2022.06.15 |
[Algorithm] JavaScript, Level1. 행렬의 덧셈 (0) | 2022.06.15 |
[Algorithm] JavaScript, Level1. x만큼 간격이 있는 n개의 숫자 (0) | 2022.06.15 |