하샤드 수

문제 링크

하샤드 수

분석

문제 그대로 자릿수 합을 구한 뒤 나누어 떨어지는지 확인하면 됩니다.

자릿수를 구하는 방법은 %(나머지 연산자)로 10씩 나눠 1의 자릿수를 구하고 값을 저장한 뒤 원본 값은 /(나누기 연산자)로 10씩 나눠 1의 자릿수를 제거하는 것을 반복하면 됩니다.

그 후 x가 나누어 떨어지는지 확인한 후 값을 반환합니다.

풀이

bool solution(int x) {
    bool answer = true;
    
    int num = x;
    int digitSum = 0;
    
    while (num)
    {
        digitSum += num % 10;
        num /= 10;
    }
    
    (x % digitSum == 0) ? answer = true : answer = false;
    
    return answer;
}

while문에서 자릿수의 합을 구합니다.

삼항연산자에서 하샤드 수인지 계산합니다.

성능 요약

테스트 1 〉 통과 (0.01ms, 4.17MB)
테스트 2 〉 통과 (0.01ms, 4.14MB)
테스트 3 〉 통과 (0.01ms, 4.22MB)
테스트 4 〉 통과 (0.01ms, 4.16MB)
테스트 5 〉 통과 (0.01ms, 4.45MB)
테스트 6 〉 통과 (0.01ms, 4.16MB)
테스트 7 〉 통과 (0.01ms, 4.14MB)
테스트 8 〉 통과 (0.01ms, 4.14MB)
테스트 9 〉 통과 (0.01ms, 4.14MB)
테스트 10 〉 통과 (0.01ms, 4.15MB)
테스트 11 〉 통과 (0.01ms, 4.21MB)
테스트 12 〉 통과 (0.01ms, 4.15MB)
테스트 13 〉 통과 (0.01ms, 4.19MB)
테스트 14 〉 통과 (0.01ms, 4.21MB)
테스트 15 〉 통과 (0.01ms, 4.2MB)
테스트 16 〉 통과 (0.01ms, 4.21MB)
테스트 17 〉 통과 (0.01ms, 4.16MB)

Programmers 카테고리 내 다른 글 보러가기

댓글남기기