0부터 9까지의 숫자 중 일부가 들어있는 정수 배열 numbers가 매개변수로 주어집니다. numbers에서 찾을 수 없는 0부터 9까지의 숫자를 모두 찾아 더한 수를 return 하도록 solution 함수를 완성해주세요.
numbers | result |
---|---|
[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의 길이가 최대 9까지고, 모든 원소가 다 다르고, 0에서 9까지 중 없는 숫자를 찾아 더하는 것이라면 아예 총 합계에서 있는 숫자를 하나씩 빼는 게 빠르지 않을까?
public int solution(int[] numbers) {
int answer = 0;
for (int i = 0; i <= 9; i++) {
answer+=i;
}
for (int j : numbers) {
answer -= j;
}
return answer;
}
출처 - https://school.programmers.co.kr/learn/courses/30/lessons/86051