프로그래머스 Lv.1 없는 숫자 더하기

J·2023년 6월 15일
0

programmers

목록 보기
18/33

문제 링크 - 없는 숫자 더하기


문제 설명

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

풀이

  1. 0~9 까지의 숫자가 들어간 arr 배열을 filter 메서드를 통해 numbers 배열에 포함되지 않은 요소만 반환함.
  2. 필터링된 arr 배열을 reduce 메서드를 이용해 숫자의 합 반환.

코드

function solution(numbers) {
    let arr = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9].filter(v => !numbers.includes(v));
    return arr.reduce((acc, cur) => acc + cur, 0);
}

다른 사람의 코드

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

생각

  • 애초에 배열을 만들 필요가 없었음. ~_~
profile
벨로그로 이사 중

0개의 댓글

관련 채용 정보