일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | 5 | ||
6 | 7 | 8 | 9 | 10 | 11 | 12 |
13 | 14 | 15 | 16 | 17 | 18 | 19 |
20 | 21 | 22 | 23 | 24 | 25 | 26 |
27 | 28 | 29 | 30 |
- .map()
- arr.push()
- 자바스크립트의 탄생배경
- 가우스의 공식
- 행렬...
- a && b
- 자바스크립트의 특징
- for반복문
- 어려운데ㅠㅠ
- Promise.all()
- Math.min
- Ajax란?
- 프로그래머스 공원 산책
- 소름돋는 알고리즘
- .split()
- 소오름~
- array.reduce()
- 프로그래머스
- 자바스크립트와 ECMAScript
- 삼항연산자
- 구문과 의미
- ES6 브라우저 지원 현황
- async-await
- 알고리즘
- !x.includes()
- 배열 최솟값
- for문
- JavaScript
- 프로그래밍이란
- 자바스크립트
- Today
- Total
Ming's develop story
알고리즘 - 하샤드 수 (21.11.13) 본문
- 하샤드 수
양의 정수 x가 하샤드 수이려면 x의 자릿수의 합으로 x가 나누어져야 합니다. 예를 들어 18의 자릿수 합은 1+8=9이고, 18은 9로 나누어 떨어지므로 18은 하샤드 수입니다. 자연수 x를 입력받아 x가 하샤드 수인지 아닌지 검사하는 함수, solution을 완성해주세요.
제한 조건- x는 1 이상, 10000 이하인 정수입니다.
10 | true |
12 | true |
11 | false |
13 | false |
입출력 예 #1
10의 모든 자릿수의 합은 1입니다. 10은 1로 나누어 떨어지므로 10은 하샤드 수입니다.
입출력 예 #2
12의 모든 자릿수의 합은 3입니다. 12는 3으로 나누어 떨어지므로 12는 하샤드 수입니다.
입출력 예 #3
11의 모든 자릿수의 합은 2입니다. 11은 2로 나누어 떨어지지 않으므로 11는 하샤드 수가 아닙니다.
입출력 예 #4
13의 모든 자릿수의 합은 4입니다. 13은 4로 나누어 떨어지지 않으므로 13은 하샤드 수가 아닙니다.
내 풀이
첫번째 방법으로 해본것은 문자열로 바꿔서 하는것이었다.
x+''로 문자열로 변환시켜준뒤 각각의 자리수를 split('')으로 분리시켜주었다.
for문 안에서 각 자리수를 parseInt()를 통해 정수로 변환해주며 미리 지정해 두었던 변수 sum에 더해준다.
마지막으로 삼항연산자를 이용, x % sum == 0 (x를 sum으로 나눴을때의 나머지가 0인가?)이 참이면 true, 거짓이면 false를 반환하도록 했다.
또 다른 풀이로는 숫자로만 한번 코드식을 짜봤다.
다른 문제들에서 그래왔듯 나머지를 sum에 더해주면서 Math.floor를 통해 각 자릿수의 합을 sum에 더해준다.
그리고 기존 x에 sum을 나눠서 나머지가 0이면 true, 아니면 false를 반환하게 한다.
여기서 주의해야 할 점은 x는 계속 변하기 때문에 마지막 계산을 해줄 oriX로 대체 하였다.
'스파르타코딩클럽 - 항해99 > 항해99 Chapter2 - 알고리즘 기초' 카테고리의 다른 글
알고리즘 - 정수 제곱근 판별 (21.11.13) (0) | 2021.11.13 |
---|---|
알고리즘 - 정수 내림차순으로 배치하기 (21.11.13) (0) | 2021.11.13 |
알고리즘 - 자릿수 더하기 (21.11.12) (0) | 2021.11.12 |
알고리즘 - 이상한 문자 만들기 (21.11.12) (0) | 2021.11.12 |
알고리즘 - 부족한 금액 계산하기 (21.11.12) (0) | 2021.11.12 |