본문 바로가기

개발(합니다)/알고리즘&코테

알고리즘 단계별로 풀어보기 : BOJ-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보다 작은 자연수이다.


출력

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


예제 입력

150

266

427


예제 출력

3

1

0

2

0

0

0

2

0

0


내 풀이

import java.io.BufferedReader;
import java.io.BufferedWriter;
import java.io.IOException;
import java.io.InputStreamReader;
import java.io.OutputStreamWriter;

public class Main {
//  한자리 씩 데이터를 가져와서 해당 숫자가 몇인지 확인하고 개수를 세어봅니다.
    public static void main(String args[]) {
        BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
        BufferedWriter bw = new BufferedWriter(new OutputStreamWriter(System.out));

        try {
            int num1 = Integer.parseInt(br.readLine());
            int num2 = Integer.parseInt(br.readLine());
            int num3 = Integer.parseInt(br.readLine());
//              int num1 = 150;
//              int num2 = 266;
//              int num3 = 427;
//              17037300
            int[] numList = numCheck(num1, num2, num3);
//          입력 받은 3개의 숫자를 함수에게 전달하고 정수형 배열을 반환받습니다.

            for (int i : numList) {
//              배열을 출력합니다.
                bw.write(String.valueOf(i));
                bw.newLine();
            }
            bw.flush();
            bw.close();
        } catch (NumberFormatException e) {
            e.printStackTrace();
        } catch (IOException e) {
            e.printStackTrace();
        }
    }

    private static int[] numCheck(int num1, int num2, int num3) {
        int mul = num1 * num2 * num3;
//      3개의 숫자를 곱합니다..
        int[] count = new int[10];
//      0-9까지의 배열을 선언합니다.
        int temp = 0;
//      나머지를 저장할 변수를 선언합니다.

        while (mul != 0) {
            temp = mul % 10;
//          1의 자리를 구합니다.
            mul = mul / 10;
//          1의 자리를 제거합니다.
            switch (temp) {
//          구한 1의 자리의 숫자에 맞는 배열을 찾아 증분합니다.
            case 0:
                count[temp]++;
                break;
            case 1:
                count[temp]++;
                break;
            case 2:
                count[temp]++;
                break;
            case 3:
                count[temp]++;
                break;
            case 4:
                count[temp]++;
                break;
            case 5:
                count[temp]++;
                break;
            case 6:
                count[temp]++;
                break;
            case 7:
                count[temp]++;
                break;
            case 8:
                count[temp]++;
                break;
            case 9:
                count[temp]++;
                break;
            }
        }
        return count;
    }
}


내 풀이 해석

입력 받은 세 수를 함수로 전달합니다.
전달 받은 세 수를 곱하고 0이 될때까지 반복하여 10의 나머지를 이용하여 1의 자리를 구해 카운트합니다.


반응형