[프로그래머스] 하샤드 수

개발잘하기프로젝트·2020년 12월 2일
0
post-thumbnail

🤔 문제

프로그래머스 - 하샤드 수

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

❗️ 제한

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

💡 접근

solution 1은 양의 정수 x에 대해서 각 자리수로 분리한 배열을 만들고 각 요소의 합 sum을 구한 후 x % sum === 0 즉, 나누어 떨어질 경우 true, 아닐 경우 false를 리턴하도록 했다.

solution 2map메서드를 이용하지 않고 reduce메서드에서 +a, +b와 같이 string을 number로 타입 변환을 해준 뒤 총 합을 구한 후 harshad값을 확인해서 그 결과를 리턴했다.

아래 참고에 하샤드 수에 대한 링크를 걸어두었다.

🧑🏻‍💻 코드

// solution 1
function solution(x) {
  const sum = [...`${x}`].map(v => parseInt(v, 10)).reduce((a, b) => a + b, 0);
  const harshad = !(x % sum);
  return harshad;
}

// solution 2
function solution(x) {
  const sum = [...`${x}`].reduce((a, b) => +a + +b, 0);
  const harshad = !(x % sum);
  return harshad;
}

solution(13);

📝 참고

wikipedia - 하샤드 수

profile
🏠 ☕️ 🎞 🌿 + 🧑🏻‍💻

0개의 댓글