프로그래머스 알고리즘 문제 기록/Lv. 1
없는 숫자 더하기
Lust3r
2024. 5. 13. 20:26
728x90
문제
https://school.programmers.co.kr/learn/courses/30/lessons/86051
프로그래머스
코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.
programmers.co.kr
내 답안 / 다른 사람들의 답안
import Foundation
func solution(_ numbers:[Int]) -> Int {
return (0...9).filter { !numbers.contains($0) }.reduce(0, +)
}
- 0부터 9까지 들어있는 범위에서 numbers에 포함되지 않은 수를 구해 더해주는 방법을 떠올릴 수 있었다.
// 풀이 1
func solution(_ numbers: [Int]) -> Int {
return (0...9).filter { !numbers.contains($0) }.reduce(0, +)
}
// 풀이 2
import Foundation
func solution(_ numbers:[Int]) -> Int {
return 45-numbers.reduce(0, +)
}
- 풀이 2번이 조금 놀라웠다. 0~9를 더한 값에서 numbers의 더한 값을 빼주면 동일한 결과가 나온다.