문제 설명

0부터 9까지의 숫자 중 일부가 들어있는 정수 배열 numbers가 매개변수로 주어집니다. numbers에서 찾을 수 없는 0부터 9까지의 숫자를 모두 찾아 더한 수를 return 하도록 solution 함수를 완성해주세요.

제한 조건

1 ≤ numbers의 길이 ≤ 9
0 ≤ numbers의 모든 원소 ≤ 9
numbers의 모든 원소는 서로 다릅니다.

입출력 예

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

💡문제 해결💡

0부터 10까지 돌며 있는 숫자는 0을 곱해서 answer에 더하고 있으면 1을 곱해서 그 수를 answer에 더한다

작성 코드

class Solution {
    public int solution(int[] numbers) {
            int answer = 0;
            
            for (int i = 0; i < 10; i++) {
                int sign = 1;
                for (int j : numbers) {
                    if (i == j){
                        sign = 0;
                    }
                }
                answer = answer + sign * i;
            }
            return answer;
        }
}

그 외 풀이

0부터 10까지 더하면 45인 점을 이용해서 배열의 수를 뺀다

class Solution {
    public int solution(int[] numbers) {
        int sum = 45;
        for (int i : numbers) {
            sum -= i;
        }
        return sum;
    }
}

45에서 배열의 수를 빼는 방법을 이용했을 때, 스트림의 sum()으로 배열의 전체 합을 구하고 45에서 빼면 간단할 듯

profile
안녕하세요. Chat JooPT입니다.

0개의 댓글