Algorithm/Jungol (수학1)

[1430] 숫자의 개수

whereareyoung 2023. 9. 19. 10:51

문제

세 개의 자연수 A, B, C가 주어질 때 A×B×C를 계산한 결과에 0부터 9까지 각각의 숫자가 몇 번씩 쓰였는지를 구하는 프로그램을 작성하시오.

 

예를 들어 A = 150, B = 266, C = 427 이라면 A × B × C = 150 × 266 × 427 = 17,037,300 이 되고, 

계산한 결과 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








0


<입력의 설계>

- 입력받을 변수 a, b, c를 선언

- a * b * c 의 값을 저장할 변수 sum 을 선언 

- 0 ~ 9 까지의 숫자가 몇번 등장하였는지 체크 할 배열 선언 후 초기화 

int a, b, c;
int sum;
int arr[10] = {};

- a, b, c 를 입력받고 a * b * c 의 값을 sum 에 저장

scanf("%d %d %d", &a, &b, &c);
sum = a * b * c;

 

출력형식

- 1의 자리수를 검출해 내는 식 " n % 10 " 을 활용, 검출된 숫자가 출력되면 배열 arr[검출된 숫자] 에 1을 더해주는 식을 짠다. 

arr[sum % 10] += 1;

- " sum / 10 " 을 활용해 한자리씩 낮춰주면서 sum 의 값이 0이 될때까지 반복한다. 

while (1)
{
	arr[sum % 10] += 1;
	sum = sum / 10;
	if (sum == 0) break;
}

이 방식으로 각 arr[0~9] 의 숫자에 숫자가 검출된 만큼 +1을 할 수 있다. 

 

- 값이 잘 들어간 arr 배열을 반복문을 사용해 출력하여 준다.

for (int i = 0; i < 10; i++)
{
	printf("%d\n", arr[i]);
}

 

 

제출답변

#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>

int main()
{
	int a, b, c;
	int sum;
	int arr[10] = {};

	scanf("%d %d %d", &a, &b, &c);
	sum = a * b * c;

	while (1)
	{
		arr[sum % 10] += 1;
		sum = sum / 10;
		if (sum == 0) break;
	}

	for (int i = 0; i < 10; i++)
	{
		printf("%d\n", arr[i]);
	}

	return 0;
}

'Algorithm > Jungol (수학1)' 카테고리의 다른 글

[1658] 최대공약수와 최소공배수  (0) 2023.09.19
[2809] 약수  (0) 2023.09.19
[1402] 약수구하기  (0) 2023.09.19
[1071] 약수와 배수  (0) 2023.09.19
[1691] 곱셈  (0) 2023.09.19