Home 221110_Algorithm | 하샤드 수(Lv.1)
Post
Cancel

221110_Algorithm | 하샤드 수(Lv.1)

하샤드 수(Lv.1)


문제 설명

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


제한사항

  • x는 1 이상, 10000 이하인 정수


입출력 예시

arrreturn
10true
12true
11false
13false


1
2
3
4
5
6
7
8
9
function solution(x) {
  var answer = true;

  let arr = String(x).split("").map(Number);
  //문자열 상태면 배열의 합을 구할 수가 없어 map(Number) 추가=>문자열 배열을 숫자형 배열로 변경해줌
  let sum = arr.reduce((a, b) => a + b);

  return x % sum == 0;
}




나름 풀이

x의 값을 배열로 변경하여 합을 구하고 그 합으로 하샤드 수인지 확인함

  • for 반복문 사용 없이 하고 싶어서 배열의 합을 reduce로 구함
  • 나온 합으로 입력값을 나눴을 때 0으로 나누어 떨어지면 true / 나머지가 있다면 false로 출력
This post is licensed under CC BY 4.0 by the author.