Algorithm/Baekjoon(Java)

[백준/JAVA] 2577 : 숫자의 개수

비망노트 2022. 7. 15. 23:00
문제

세 개의 자연수 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까지의 숫자가

각각 몇 번 쓰였는지 차례로 한 줄에 하나씩 출력한다.

 

예제 입력 예제 출력
150
266
427
3
1
0
2
0
0
0
2
0
0

 

⭕ 풀이

import java.util.*;
import java.io.*;

public class Main{
    public static void main(String[] args)throws IOException{
        BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
        StringBuilder sb = new StringBuilder();
        String numStr = String.valueOf((Integer.parseInt(br.readLine())*Integer.parseInt(br.readLine())*Integer.parseInt(br.readLine())));
        br.close();
        String[] numArr =numStr.split("");
        int[] countArr = new int[10];
        
        int x=0;
        while(x<numArr.length){
            countArr[Integer.parseInt(numArr[x])]++;
            x++;
        }
        for(int i=0;i<countArr.length;i++){
            sb.append(countArr[i]).append("\n");
        }
        System.out.print(sb);
    }
}

✅ 우선 평소 사용하던 StringTokenizer로는 공백이아닌 "" 붙어있는 문자열은 분리가 되지않길래 split을 사용했다.

1. 우선 세 숫자를 곱한값을 문자열 배열로 만들었다.

2. 길이10짜리 countArr를 생성해 0으로 초기화시켰다.

3. 곱합값을 문자열로 나눠 담아둔 numArr 배열의 각 인덱스, 즉 곱한값의 각 자릿수에 쓰인 숫자를 정수로 형변환해서

   countArr를 증가시켰다.

4. 즉 곱합값이 123456 이라면 numArr[0]은 1이므로 countArr의 [1] 인덱스 1번을 증가시킨다.

5. 이후 모든 증가반복문을 끝낸 countArr의 각 인덱스값을 sb에 넣고 출력한다.

 

 

⭕ 재풀이

import java.util.*;
import java.io.*;

public class Main{
    public static void main(String[] args)throws IOException{
        BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
        StringBuilder sb = new StringBuilder();
        int A = Integer.parseInt(br.readLine());
        int B = Integer.parseInt(br.readLine());
        int C = Integer.parseInt(br.readLine());
        int total = A*B*C;
        br.close();
        int[] countArr = new int[10];
        while(total>0){
            countArr[total%10]++;
            total /= 10;
        }
        for(int i=0;i<countArr.length;i++){
            sb.append(countArr[i]).append("\n");
        }
        System.out.print(sb);
    }
}

첫 풀이가 형변환 과정이 많은것같아서 문자열분리없이 간략하게 풀어봤다.

실행속도는 동일했다.

 

 

 

 

-출처

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