백준 알고리즘 문제 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까지의 숫자가 각각 몇 번 쓰였는지 차례로 한 줄에 하나씩 출력한다.

코드 1
#include <stdio.h>
int main(void) {
int A, B, C;
int i, result;
int count[10] = { 0 };
scanf("%d %d %d", &A, &B, &C);
result = A * B * C;
for ( ; ; ) {
switch (result % 10) {
case 0:
count[0] ++;
break;
case 1:
count[1] ++;
break;
case 2:
count[2] ++;
break;
case 3:
count[3] ++;
break;
case 4:
count[4] ++;
break;
case 5:
count[5] ++;
break;
case 6:
count[6] ++;
break;
case 7:
count[7] ++;
break;
case 8:
count[8] ++;
break;
case 9:
count[9] ++;
break;
}
if (result < 10) break;
result = result / 10;
}
for (i = 0; i <= 9; i++) {
printf("%d\n", count[i]);
}
}
코드 2
#include <stdio.h>
int main(void) {
int a, b, c, i, result;
int count[10] = { 0 };
scanf("%d %d %d", &a, &b, &c);
result = a * b * c;
for (i = result ; i > 0; i /= 10) {
count[i % 10]++;
}
for (i = 0; i < 10; i++){
printf("%d\n", count[i]);
}
}
메모
세 자연수의 곱의 각 자릿수의 숫자를 얻기 위해서 10으로 나누면서 나머지를 얻어 연산하였다.
처음에 쓴 코드가 switch문 때문에 너무 길어서 코드 길이를 줄이려고 배열 인덱스에서 바로 연산!!
https://www.acmicpc.net/problem/2577
2577번: 숫자의 개수
첫째 줄에 A, 둘째 줄에 B, 셋째 줄에 C가 주어진다. A, B, C는 모두 100보다 크거나 같고, 1,000보다 작은 자연수이다.
www.acmicpc.net
'BAEK JOON ㅡ C' 카테고리의 다른 글
| [BAEK JOON/C] 8958 ㅡ OX퀴즈 (0) | 2022.05.28 |
|---|---|
| [BAEK JOON/C] 3052 ㅡ 나머지 (0) | 2022.05.28 |
| [BAEK JOON/C] 2562 ㅡ 최댓값 (0) | 2022.05.21 |
| [BAEK JOON/C] 10818 ㅡ 최소, 최대 (0) | 2022.05.19 |
| [BAEK JOON/C] 1110 ㅡ 더하기 사이클 (0) | 2022.05.18 |