[CODING TEST]::LV1 없는 숫자 더하기

kimsoyeon·2022년 5월 31일
0
post-custom-banner

[문제]

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

[제한]

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

[입출력 예]

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

[answers.js]

function solution(numbers) {
  let answer = -1;
  const basicNum = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9];
  let filterArr = basicNum.filter((e) => !numbers.includes(e));
  answer = filterArr.reduce((num1, num2) => {
    return num1 + num2;
  }, 0);
  return answer;
}

다른 사람 풀이

0-9 까지 전체 합에서 numbers 숫자 합을 빼면 된다니.........

function solution(numbers) {
    return 45 - numbers.reduce((cur, acc) => cur + acc, 0);
}

[codesandbox]
https://codesandbox.io/s/coding-test-daily-36-kl93dm

profile
i am korean dobby
post-custom-banner

0개의 댓글