728x90
문제 설명
0부터 9까지의 숫자 중 일부가 들어있는 정수 배열 `numbers`가 매개변수로 주어집니다. `numbers`에서 찾을 수 없는 0부터 9까지의 숫자를 모두 찾아 더한 수를 return 하도록 solution 함수를 완성해 주세요.
제한 사항
- 1 ≤ numbers의 길이 ≤ 9
- 0 ≤ numbers의 모든 원소 ≤ 9
- numbers의 모든 원소는 서로 다릅니다.
입출력 예
입출력 예 설명
- 입출력 예 #1
5, 9가 numbers에 없으므로, 5 + 9 = 14를 return 해야 합니다. - 입출력 예 #2
1, 2, 3이 numbers에 없으므로, 1 + 2 + 3 = 6을 return 해야 합니다.
코드 생각
- 배열에서 1 ~ 9 까지의 숫자 중에서 존재하는 숫자인지 찾기 위해 2중 for문을 사용해야겠다.
- 1~9까지의 숫자를 순회하면서 없는 숫자를 찾아볼까 생각했는데, 없는 숫자의 합을 구하는 문제니까 존재하는 숫자를 빼서 구할 수 있겠다.
- 1~9의 합에서 배열에 존재하는 숫자를 빼면 없는 숫자의 합이겠다.
Solution.java
//없는 숫자 더하기
class Solution {
public int solution(int[] numbers) {
int answer = 0;
int temp = 0;
int sum = 0;
for(int i=0;i<numbers.length;i++){
for(int j=0;j<10;j++){
if(numbers[i]==j){
temp += numbers[i];
}
}
}
for(int i=0;i<10;i++){
sum+=i;
}
answer = sum - temp;
return answer;
}
}
새롭게 알게 된 기술 & 주요 기술
무작정 처음에는 배열을 순회하면서 존재하지 않는 숫자 하나하나를 찾으려 하였습니다. 하지만 코드를 작성하다 보니 반대로 전체 숫자의 합에서 배열에 존재하는 숫자를 빼면 존재하지 않는 숫자의 합을 구할 수 있겠다는 생각을 해낼 수 있었습니다.
문제를 바라볼 때 다양한 시각과 관점에서 생각하면 더 좋은 문제해결 방법을 찾을 수 있음을 느낄 수 있었습니다.
실행결과
문제 URL
https://school.programmers.co.kr/learn/courses/30/lessons/86051
프로그래머스
코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.
programmers.co.kr
728x90
'수수한 코딩세상 > Code Kata' 카테고리의 다른 글
[Programmers][MySQL] NULL 처리하기 (IFNULL, IF, IS NULL, CASE, COALESCE) (0) | 2024.08.20 |
---|---|
[Programmers][Java] 제일 작은 수 제거하기 (배열의 크기는 0이 될 수 없다) (0) | 2024.08.16 |
[Programmers][Java] 서울에서 김서방 찾기 (배열에서 특정 문자열 위치 찾기) (0) | 2024.08.11 |
[Programmers][Java] 음양 더하기 (배열을 이용해 부호 식별) (0) | 2024.08.08 |
[Programmers][Java] 콜라츠 추측 (정수형 자료형의 중요성) (0) | 2024.07.31 |