ss 프로그래머스 1단계 : 하샤드 수
본문 바로가기
알고리즘

프로그래머스 1단계 : 하샤드 수

by 꿈나무개발 2022. 11. 8.
728x90

알고리즘13

📝 문제 설명

양의 정수 x가 하샤드 수이려면 x의 자릿수의 합으로 x가 나누어져야 합니다. 예를 들어 18의 자릿수 합은 1+8=9이고, 18은 9로 나누어 떨어지므로 18은 하샤드 수입니다. 자연수 x를 입력받아 x가 하샤드 수인지 아닌지 검사하는 함수, solution을 완성해주세요.

👉 제한 조건

- x는 1 이상, 10000 이하인 정수입니다.

👉 입출력 예

arr return
10 true
12 true
11 false
13 false

👉 입출력 예 설명

- 10의 모든 자릿수의 합은 1입니다. 10은 1로 나누어 떨어지므로 10은 하샤드 수입니다.
- 12의 모든 자릿수의 합은 3입니다. 12는 3으로 나누어 떨어지므로 12는 하샤드 수입니다.
- 11의 모든 자릿수의 합은 2입니다. 11은 2로 나누어 떨어지지 않으므로 11는 하샤드 수가 아닙니다.
- 13의 모든 자릿수의 합은 4입니다. 13은 4로 나누어 떨어지지 않으므로 13은 하샤드 수가 아닙니다.

✌️ 나의 풀이

x를 문자열로 만들어 하나씩 분리시킨 후 for문을 이용해 자릿수들을 더해줍니다. 그리고 삼항연산자를 통해 true나 false를 반환합니다.
function solution(x) {
    let sum = 0;
    let arr = String(x).split('');

    for(let i=0; i<arr.length; i++) {
        sum += Number(arr[i]);
    }

    return (x % sum == 0) ? true : false;
}

👍 다른 풀이

한 줄 만에 끝나는 방법입니다.
function Harshad(n){
    return !(n % (n + "").split("").reduce((a, b) => +b + +a ));
}
728x90
반응형

댓글


HTML
CSS
JAVASCRIPT

JAVASCRIPT

자세히보기
광고 준비중입니다.