문제 설명
0부터 9까지의 숫자 중 일부가 들어있는 정수 배열 numbers가 매개변수로 주어집니다. numbers에서 찾을 수 없는 0부터 9까지의 숫자를 모두 찾아 더한 수를 return 하도록 solution 함수를 완성해주세요.
제한사항
- 1 ≤ numbers의 길이 ≤ 9
- 0 ≤ numbers의 모든 원소 ≤ 9
- numbers의 모든 원소는 서로 다릅니다.
입출력 예numbersresult
[1,2,3,4,6,7,8,0] | 14 |
[5,8,4,0,6,7,9] | 6 |
입출력 예 설명
입출력 예 #1
- 5, 9가 numbers에 없으므로, 5 + 9 = 14를 return 해야 합니다.
입출력 예 #2
- 1, 2, 3이 numbers에 없으므로, 1 + 2 + 3 = 6을 return 해야 합니다.
알고리즘
- 주어진 numbers에서 0~9 까지 숫자중 없는 숫자를 판별한다.
- 없는 숫자를 더한다.
정답 코드
class Solution {
fun solution(numbers: IntArray): Int {
var answer = 0
val bArray = Array(10) { false }
numbers.forEach { i ->
bArray[i] = true
}
bArray.forEachIndexed { index, b ->
if (!b) {
answer += index
}
}
return answer
}
}
체감난이도: 최하
다른 사람의 정답 풀이

-> 0..9 를 통해 배열을 만들어내고 filterNot을 통해 numbers에 포함되었는지를 확인 후 반환된 배열을 더하는 sum()을 이용하셨다.

-> 애초에 0~9까지 더한 45의 값에 numbers의 합을 뺐다...... 이런 이런..... 생각을...
-> 이런분들은 코틀린에 대한 이해도와 알고리즘의 능력이 얼마나 높으신건지 가늠이 가지 않는다. 8줄의 코드를 단 한줄로 표현해내는 것이야 말로 코틀린의 진정한 매력이라고 볼 수 있는 것 같다.
'프로그래머스 코딩테스트 연습 > Lv.1' 카테고리의 다른 글
[프로그래머스] (카카오 문제) 개인정보 수집 유효기간(Kotlin, 코틀린) (0) | 2023.02.13 |
---|---|
[프로그래머스] Lv.1 숫자 문자열과 영단어(Kotlin, 코틀린) (0) | 2023.02.10 |
[프로그래머스] 부족한 금액 계산하기 (Kotlin, 코틀린) (0) | 2023.02.08 |
프로그래머스 둘만의 암호 (코틀린, Kotlin) (0) | 2023.02.03 |
프로그래머스 코딩 테스트: 푸드파이터 대회 (0) | 2023.01.24 |
댓글