세 개의 자연수 A, B, C가 주어질 때 A × B × C를 계산한 결과에 0부터 9까지 각각의 숫자가 몇 번씩 쓰였는지를 구하는 프로그램을 작성하시오.
예를 들어 A = 150, B = 266, C = 427 이라면 A × B × C = 150 × 266 × 427 = 17037300 이 되고, 계산한 결과 17037300 에는 0이 3번, 1이 1번, 3이 2번, 7이 2번 쓰였다.
입력
첫째 줄에 A, 둘째 줄에 B, 셋째 줄에 C가 주어진다. A, B, C는 모두 100보다 크거나 같고, 1,000보다 작은 자연수이다.
출력
첫째 줄에는 A × B × C의 결과에 0 이 몇 번 쓰였는지 출력한다. 마찬가지로 둘째 줄부터 열 번째 줄까지 A × B × C의 결과에 1부터 9까지의 숫자가 각각 몇 번 쓰였는지 차례로 한 줄에 하나씩 출력한다.
예제 입력 1
150
266
427
예제 출력 1
3
1
0
2
0
0
0
2
0
0
const fs = require('fs');
const input = fs.readFileSync('dev/stdin').toString().trim().split('\n').map(val=>+val);
const num = input.reduce((acc,cur)=> {return acc*cur});
const arr = num.toString().split('').map(val=>+val);
for(let i=1;i<10;i++){
let newArr = arr.filter((el)=> el === i);
console.log(newArr.length)
}
세 개의 수를 받아 곱한 값을 toString().split('').map() 하여 각 숫자를 배열에 저장하였다. 그리고 그 배열에서 filter() 메서드를 활용해서 newArr에 0 부터 9까지의 숫자를 차례로 뽑아 배열에 담아서 length를 출력하는 방식으로 풀었다.
reduce 메서드를 활용하면 배열 안의 모든 요소를 더하거나 곱하는 것이 가능하다.
세 개의 수가 들어온다는 것을 알고 있지만 reduce() 를 써서 곱하는 것이 더 확장성 있을 것 같다는 생각이 들어서 reduce로 입력으로 받아 온 수가 들어있는 배열의 모든 값을 곱했다.
filter() 메서드를 활용하면 콜백함수에서 제시하는 조건에 맞는 요소만 뽑아 새로운 배열을 생성할 수 있다.
Array 인스턴스의 length 속성은 배열의 길이를 반환한다.