[프로그래머스] 없는 숫자 더하기

creativeBin·2022년 12월 30일
0

문제 설명

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 해야 합니다.

풀이

1) 0..9 배열 생성
2) filter를 사용해서 contains 재배열 이후 sum() 쉬웠음
3) contains

class Solution {
    fun solution(numbers: IntArray): Int {
        
        var arr = ArrayList<Int>()
        for(i in 0 .. 9) {
            arr.add(i)
        }
                       
        return arr.filter { !numbers.contains(it) }.sum()
    }
}

다른사람 풀이

filter-not 레퍼런스 참고

class Solution {
    fun solution(numbers: IntArray): Int = (0..9).filterNot(numbers::contains).sum()
}

(0..9) += 해서 나온 45에서 numbers.sum() 마이너스라... 신박하군

class Solution {
    fun solution(numbers: IntArray): Int  = 45 - numbers.sum()
}
profile
언제나 항상 즐겁게 New vibes 😎

0개의 댓글