문제 설명
양의 정수 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 |
Python
def solution(x):
st = str(x)
a = 0
for i in range(len(st)):
a += int(st[i])
return True if x%a == 0 else False
JavaScript
function solution(x) {
var num = 0;
var str = x+"";
for(let i = 0; i < str.length; i++)
num += Number(str[i]);
return x%num === 0 ? true : false;
}
C++
#include <string>
#include <vector>
using namespace std;
bool solution(int x) {
int n = 0;
int temp = x;
while(temp > 0){
n += temp%10;
temp = temp/10;
}
return x % n == 0 ? true : false;
}
'개발노트&IT > 코딩테스트' 카테고리의 다른 글
[프로그래머스|Level.1] 행렬의 덧셈 (0) | 2021.01.30 |
---|---|
[프로그래머스|Level.1] 핸드폰 번호 가리기 (0) | 2021.01.30 |
[프로그래머스|Level.1] 평균 구하기 (0) | 2021.01.28 |
[프로그래머스|Level.1] 콜라츠 추측 (0) | 2021.01.28 |
[프로그래머스|Level.1] 최대공약수와 최소공배수 (0) | 2021.01.27 |
최근댓글