Miyeon

백준 2577번 | 숫자의 개수

2021-11-21Algorithm

🔥 숫자의 개수 🔥

문제

세 개의 자연수 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까지의 숫자가 각각 몇 번 쓰였는지 차례로 한 줄에 하나씩 출력한다.

코드

let fs = require("fs");
let input = fs
  .readFileSync("/dev/stdin")
  .toString()
  .trim()
  .split("\n");

const reducer = (previousValue, currentValue) => previousValue * currentValue;
let multipliedNum = input.reduce(reducer);
let newArr = String(multipliedNum)
  .split("")
  .map(x => Number(x));
let result = "";
let count = 0;

for (let i = 0; i < 10; i++) {
  let sameNumberArr = newArr.filter(num => i === num);
  count = sameNumberArr.length;

  if (i < 9) {
    result += count + "\n";
  } else {
    result += count;
  }
}

console.log(result);

WILT : What I Learned Today 🤔

  • reduce()메서드를 사용해 세 숫자의 곱을 구했고, filter()메서드로 타겟 숫자와 같은 숫자를 담은 새로운 배열을 리턴받았다.
  • 알고리즘 문제를 풀면서 타입을 더 명확하게 체크하는 습관이 생겼다.
  • reduce()메서드의 내부 동작이 궁금해 내일 구현해보려고 한다.

참고

2577번: 숫자의 개수