없는 숫자 더하기
문제
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 해야 합니다.
solution
- 0부터 9까지의 합을 구한다
- 주어진 numbers의 합을 구한다
- 0부터 9까지의 합에서 numbers의 합을 뺀다
1 | const numbers = [1,2,3,4,6,7,8,0] |
다른 사람의 풀이를 보자..
1 | function solution(numbers){ |
깔끔쓰..
0부터9까지합 로직은 그렇다 쳐도
reduce는 생각도 못했다
reduce()에 대해 알아보자..
Array.reduce()
배열의 각 요소에 대해 주어진 리듀서(reducer)함수를 실행하고, 하나의 결과값을 반환한다
말이 어렵다..
1 | arr.reduce(callback[, initialValue]) |
사용 방법
reduce()에는 누산기가 포함되어 있기 때문에, 배열의 각 요소에 대해 함수를 실행하고 누적된 값을 출력할때 용이하다.
1 | const numbers = [1,2,3,4,5] |
예제에서 initialValue 를 0 으로 주었기 때문에 초기값이 0부터 시작해서 하나씩 누적 시켜 나간다
0+1+2+3+4+5 = 15
1 | const numbers = [1,2,3,4,5] |
initialValue 를 10 으로 주었기 때문에 초기값이 10부터 시작해서 하나씩 누적 시켜 나간다
10+1+2+3+4+5 = 15
reduce()의 콜백 함수는 4가지 인수를 받는다
1 | 1. accumulator |