728x90
문제 설명
0부터 9까지의 숫자 중 일부가 들어있는 정수 배열 numbers가 매개변수로 주어집니다. numbers에서 찾을 수 없는 0부터 9까지의 숫자를 모두 찾아 더한 수를 return 하도록 solution 함수를 완성해주세요.
제한사항
- 1 ≤ numbers의 길이 ≤ 9
- 0 ≤ numbers의 모든 원소 ≤ 9
- numbers의 모든 원소는 서로 다릅니다.
입출력 예
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 해야 합니다.
1
2
3
4
5
6
7
8
9
10
11
12
|
import java.util.Arrays;
import java.util.List;
import java.util.stream.Collectors;
import java.util.stream.IntStream;
class Solution {
public int solution(int[] numbers) {
List<Integer> list1 = IntStream.range(0, 10).boxed().collect(Collectors.toList());
List<Integer> list2 = Arrays.stream(numbers).boxed().collect(Collectors.toList());
list1.removeAll(list2);
return list1.stream().reduce(0,(a,b)-> a + b);
}
}
|
cs |
list1 : 0~9까지의 List를 IntStream을 이용하여 만듭니다. list2 : 배열을 이용하여 IntStream을 만들고 다시 List로 만듭니다. list1에서 list2를 모두 지웁니다. reduce()를 이용하여 합계를 구합니다. 마지막 줄을 다음과 같이 바꿔도 된다. return list.stream().mapToInt(v->v).sum();
|
1
2
3
4
5
6
7
|
import java.util.Arrays;
import java.util.stream.IntStream;
class Solution {
public int solution(int[] numbers) {
return IntStream.range(0, 10).sum() - Arrays.stream(numbers).sum();
}
}
|
cs |
하하하 생각의 전환이 필요합니다. 0~9까지 합에서 배열의 합을 빼는 없는수의 합계가 됩니다. 대단한 생각이지 않습니까? |
728x90
'프로그래머스 코딩(자바) > Level 1' 카테고리의 다른 글
Programmers Level 1 - 수박수박수박수박수박수? (0) | 2023.03.09 |
---|---|
Programmers Level 1 - 가운데 글자 가져오기 (0) | 2023.03.09 |
Programmers Level 1 - 제일 작은 수 제거하기 (0) | 2023.03.09 |
Programmers Level 1 - 음양 더하기 (0) | 2023.03.09 |
Programmers Level 1 - 핸드폰 번호 가리기 (0) | 2023.03.09 |