Taene's

[백준] Class1-숫자의 개수 C++ 2577번 본문

백준/Class1

[백준] Class1-숫자의 개수 C++ 2577번

taene_ 2023. 8. 23. 17: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까지의 숫자가 각각 몇 번 쓰였는지 차례로 한 줄에 하나씩 출력한다.

예제 입력 1 복사

150
266
427

예제 출력 1 복사

3
1
0
2
0
0
0
2
0
0

 

소스코드 1:

#include <iostream>
#include <string>
using namespace std;


int main()
{
	int a, b, c;
	cin >> a >> b >> c;

	int k[10] = { 0, };	//0 1 2 3 4 5 6 7 8 9
	string n = to_string(a * b * c);	//17037300
	char q[1000];

	for (int i = 0; i < n.length(); i++)
	{
		q[i] = n[i];
		++k[q[i] - '0'];
	}

	for (int i = 0; i < 10; i++)
	{
		cout << k[i] << "\n";
	}


}

 

소스코드 2:

#include <iostream>
#include <string>
using namespace std;


int main()
{
	int a, b, c;
	cin >> a >> b >> c;

	int k[10] = { 0, };	//0 1 2 3 4 5 6 7 8 9
	int n = a * b * c;	//17037300

	for (int i = n; i > 0; i /= 10)
	{
		++k[i % 10];
	}

	for (int i = 0; i < 10; i++)
	{
		cout << k[i] << "\n";
	}

}

접근방법:

1. 세자리의 세 자연수를 곱한 값을 string으로 변환해서 각 숫자를 char 배열에 넣고, 0으로 초기화 해준 k배열(0~9)을 ++ 해주고, k[i]를 출력한다.

2. 각 자연수를 곱한 값을 변수 n이라 하고, n을 for문으로 10으로 계속 나눠준다. 나눠준 값을 10으로 나눈 나머지(일의 자리, 십의 자리, ...)를 ++k[i%10]으로 카운트하고 k[i]를 출력한다.