본문 바로가기
알고리즘

하샤드 수

by 코딩달림 2022. 11. 17.
728x90

프로그래머스 : 하샤드 수

숫자의 자릿수 합을 구해 판별하는 문제입니다.


문제 설명

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

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

입출력 예

arr 결과
10 true
12 true
11 false
13 false

1. 해설

소스보기
function solution(x) {
    var answer = 0;
    
    x.toString().split("").forEach((e)=>{
        answer += parseInt(e);
    });

    return x % answer == 0 ? true : false
}

숫자를 각각 나누기 위해 우선 문자열로 바꾸고 문자열을 split( ) 메서드로 각각의 배열 값으로 만듭니다.
이 후 반복문을 통해 문자열을 parseInt( ) 메서드로 숫자로 다 시 바꾼 후 합해 자릿수 합을 구한 후 주어진 값을 나눠 나온 나머지로 짝수 홀수를 판별하면 정답이 됩니다.


2. 다른 풀이

소스보기
function solution(x) {
    return x%eval([...x.toString()].join("+")) ? false : true;
}

문자열을 숫자처럼 합할 수 있는 eval 함수를 이용한 방식입니다. 다만 eval 함수는 여러가지 문제로 사용이 권장되지 않는 함수입니다.

'알고리즘' 카테고리의 다른 글

문자열 내 p와 y의 개수 구하기  (2) 2022.11.14
부족한 금액 계산하기  (2) 2022.11.11
폰켓몬  (1) 2022.11.10
가운데 글자 가져오기  (1) 2022.11.10
행렬 덧셈  (1) 2022.11.10

댓글


광고 준비중입니다.