[백준] 2577. 숫자의 개수(feat. Javascript / node.js) 알고리즘

준리·2022년 6월 13일
0

자료구조알고리즘

목록 보기
34/38
post-thumbnail
post-custom-banner

1차원 배열

: 숫자의 개수 [2577]

세 개의 자연수 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보다 작은 자연수이다.

150
266
427

예제 출력

첫째 줄에는 A × B × C의 결과에 0 이 몇 번 쓰였는지 출력한다. 마찬가지로 둘째 줄부터 열 번째 줄까지 A × B × C의 결과에 1부터 9까지의 숫자가 각각 몇 번 쓰였는지 차례로 한 줄에 하나씩 출력한다.

3
1
0
2
0
0
0
2
0
0

제출


//https://www.acmicpc.net/problem/2577

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

    const [A, B, C] = input;
    
    const firstResult = String(A * B * C);
    
    for (let i = 0; i <= 9; i++) {
        console.log(firstResult.split(i + "").length - 1);
    }


    // 다른 해답
    // for (let i = 0; i <= 9; i++) {
//     let count = 0;

//     for (let j = 0; j < x.length; j++) {
//         if (Number(x[j]) === i) {
//             count++;
//         }
//     }

//     console.log(count);
// }

무엇을 해결해야 하는가?

input을 비구조할당해준 뒤 곱해주고,
반복문을 활용해 0부터 9까지 출력해준다.
그 안에 출력값을 i 기준으로 split 한 뒤 갯수를 세어서 출력한다.
예를 들어 i=0 일 때 input 값 중 0만 가져오고, 그 배열의 갯수를 새서 -1을 해준다.

split 메서드로 문자열을 나눌 시 기준이 되는 문자를 기점으로 모든 문자열이 배열로 나뉘게 됩니다.
"aBaaaaa". split("B")의 결과는 ["a", "aaaaa"]이 나오게 됩니다.
즉 B의 개수는 하나이지만 나오는 배열의 값은 2개가 됩니다. 이를 -1을 하여 개수를 맞추어줍니다.

다른 방법은 이중 반복문을 만드는 건데, count 변수에 같은 값이 있을 때마다 값을 추가해주는 것이다.

숏코딩

profile
트렌디 풀스택 개발자
post-custom-banner

0개의 댓글