본문 바로가기
JAVA/백준 알고리즘

[백준] 2577번 숫자의 개수 - Java

by 코딩전사_추추 2022. 4. 13.
728x90
반응형

1. 문제

 

2577번: 숫자의 개수

첫째 줄에 A, 둘째 줄에 B, 셋째 줄에 C가 주어진다. A, B, C는 모두 100보다 크거나 같고, 1,000보다 작은 자연수이다.

www.acmicpc.net

문제

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

예제 입력 1 복사

150
266
427

예제 출력 1 복사

3
1
0
2
0
0
0
2
0
0

2. 문제 풀이

- a,b,c를 입력받는다.

- a*b*c의 값을 생성한다.

- 0~9까지의 수가 몇 번 나왔는지 카운트할 배열을 생성한다.

- 몫과 나머지를 넣을 변수를 만든다.

- 몫이 0이 될 때까지 10으로 나눠준다.

- for문을 통해 10으로 나누었을 때 나머지가 0~9중 어디에 해당하는지 확인하고, 해당 arr[i]에 +1을 해준다.

- 몫이 0이 되면 break; for문을 통해 arr[]를 출력한다.

import java.util.Scanner;

public class Main {

	public static void main(String[] args) {
		// TODO Auto-generated method stub

		Scanner sc = new Scanner(System.in);
		
		int a = sc.nextInt();
		int b = sc.nextInt();
		int c = sc.nextInt();
		int result = a*b*c;
		int[] arr = {0,0,0,0,0,0,0,0,0,0};

		int e = 0; //몫
		int f = 0; //나머지
		
		while(true) {
			f = result % 10; //일의자리
			e = result / 10; //일의자리를 뺸 몫
			result = e;
					
			for(int i = 0; i < arr.length; i ++) {
				if(f == i) {
					arr[i] += 1;
				}
			}
			
			if(e == 0) {
				break;
			}
		}
		
		for(int i = 0; i < arr.length; i ++) {
			System.out.println(arr[i]);
		}
		
		
	}

}
728x90
반응형