[Programmers] 없는 숫자 더하기

2022. 10. 20. 20:09기록/Programmers

    목차

문제 설명

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

나의 문제 풀이

function solution(numbers) {
    let sum = 0;
    
    for (let i = 0; i <= 9; i++) {
        if (!numbers.includes(i)) {
            sum += i;
        }
    }
    return sum;
}
  • 주어진 배열에서 0부터 9까지의 숫자가 포함되어 있는지 판별한다.
  • 포함되어 있지 않다면 합계 변수에 해당 숫자를 더해준다.
  • 모든 판별이 끝난 후 합계 변수를 반환한다.

다른 사람의 문제 풀이

function solution(numbers) {
    return 45 - numbers.reduce((cur, acc) => cur + acc, 0);
}
  • 0부터 9까지의 총 합계인 45를 미리 작성한다.
  • 주어진 숫자 배열의 요소들을 모두 누적하여 합계를 구한다. 합계의 초기값은 0이다.
  • 45에서 주어진 숫자 배열 요소들의 총 합계를 뺀다.
  • 0부터 9까지의 총 합계 - 주어진 숫자 배열 요소들의 총 합계 = 없는 숫자의 합계