[Swift 알고리즘] 프로그래머스 LV1 - 15. 하샤드 수
프로그래머스 코딩테스트 연습문제 LV1 - 15. 하샤드 수
15. 하샤드 수
- 출처: 프로그래머스 코딩 테스트 연습
- 난이도: 레벨1
- 사용언어: Swift
문제 설명
양의 정수 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 |
입출력 예 설명
입출력 예 #1 10의 모든 자릿수의 합은 1입니다. 10은 1로 나누어 떨어지므로 10은 하샤드 수입니다.
입출력 예 #2 12의 모든 자릿수의 합은 3입니다. 12는 3으로 나누어 떨어지므로 12는 하샤드 수입니다.
입출력 예 #3 11의 모든 자릿수의 합은 2입니다. 11은 2로 나누어 떨어지지 않으므로 11는 하샤드 수가 아닙니다.
입출력 예 #4 13의 모든 자릿수의 합은 4입니다. 13은 4로 나누어 떨어지지 않으므로 13은 하샤드 수가 아닙니다.
주어진 코드
func solution(_ x:Int) -> Bool {
return true
}
제출한 코드
처음 제출한 코드
func solution(_ x:Int) -> Bool {
var num = x
var arr = [Int]()
while num > 0 {
arr.append(num % 10)
num /= 10
}
num = 0
for i in arr {
num += i
}
return (x % num) == 0 ? true : false
}
다른 사람의 풀이 참고 후 수정한 코드
func solution(_ x:Int) -> Bool {
var num = x
var sum = 0
while num > 0 {
sum += (num % 10)
num /= 10
}
return x % sum == 0
}
다시 푼 코드
func solution(_ x:Int) -> Bool {
let n = Array(String(x)).map({Int(String($0))!}).reduce(0, +)
return x % n == 0 ? true : false
}
Leave a comment