Algorithm/백준

Backjoon(백준) 2577번 - 숫자의 개수(Java)

GrapeMilk 2020. 3. 20. 17:13

문제

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

 

 내 풀이

 - 세 수를 곱한 결과 값을 문자열 배열로 바꾸어, 각각의 자리수를 0 ~ 9와 판단하여, 몇개의 숫자가 쓰였는지 판단함.

package array.backjoon;

import java.util.Arrays;
import java.util.Scanner;

public class NumberCount {

    public static void main(String[] args) {
        
            
            Scanner sc = new Scanner(System.in);
            
            int A = sc.nextInt();
            int B = sc.nextInt();
            int C = sc.nextInt();
            
            int result = A * B * C;
            
            String resultS = Integer.toString(result); //int to String
            char[] arrC = resultS.toCharArray(); // String to char arr
            
            int[] arr = new int[10];
            
            for (int i = 0; i < arr.length; i++){
                for (int j = 0; j < arrC.length; j++){
                    if (Character.forDigit(i, 10) == arrC[j] ){ // int to char
                        arr[i]++;
                    }
                }
                System.out.println(arr[i]);
            }
            
        }

    

}

 

 베스트 코드

 - 문자열의 숫자를 판단할 때, i, i + 1과 같이 사용하여 변수 1개로 문자열을 비교할 수 있기 때문에 이중 for문을 사용하지 않고 for문을 1개만 사용함.

 - 내 코드는 단순히 쭉 데이터를 반복했기 때문에 2중 for문을 사용했고 베스트 코드는 버블정렬 형식으로 비교했기 때문에 for문을 한번만 사용할 수 있었음.

import java.io.BufferedReader;
import java.io.FileInputStream;
import java.io.InputStreamReader;
import java.util.Arrays;

public class Main {
	
	static long A,B,C;
	static int[] countArr;
	public static void main(String[] args) throws Exception {
		BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
		
		A = Integer.parseInt(br.readLine());
		B = Integer.parseInt(br.readLine());
		C = Integer.parseInt(br.readLine());
		
		countArr = new int[10];
		
		String temp = String.valueOf(A*B*C); //number to String
		
		for (int i = 0; i < temp.length(); i++) {
			int idx = Integer.parseInt(temp.substring(i, i + 1));
			countArr[idx]++;
		}
		
		for (int i = 0; i < countArr.length; i++) {
			System.out.println(countArr[i]);
		}
		
	}
}

 

* 참고 개념

1) int to String 

2) String to char arr

3) int to char 

4) Character.forDigit(int num, int radix)

int num = 5;
char c = Character.forDigit(num, 10);

// 숫자를 10진수를 기준으로 char형으로 바꿔줌.

5 -> '5'

5) Integer.parseInt (String to Integer)

//Integer.parseInt(String s)
//숫자형의 문자열을 인자값으로 받으면 10진수의 Integer형으로 반환해줌

Integer.parseInt("1004");

//Integer.parseInt(String s, int radix)
//숫자형의 문자열을 첫번째 인자값으로 받고, 변환할 진수값을 두번째 인자값으로 받아 그에 맞추어
//Integer형으로 반환해줌 

Integer.parseInt("1004", 16);

6) substring (문자열 자르기)

 자료 참조 ( https://coding-factory.tistory.com/126 )

String.substring(int a) // a부터 인덱스 마지막까지 문자열 자르기
String.substring(int a, int b) //a부터 b - 1 인덱스까지 문자열 자르기 

//예제

String s = "ABCDEF";

String str = s.substring(1); // "BCDEF"
String str2 = s.substring(2, 4); // "CD"