[ 문제 ]
세 개의 자연수 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까지의 숫자가 각각 몇 번 쓰였는지 차례로 한 줄에 하나씩 출력한다.
[ 작성한 코드 ]
#include <stdio.h>
int main()
{
int A,B,C,i;
int num[10]={0}; //0부터 9까지의 인덱스
scanf("%d\n%d\n%d",&A,&B,&C);
int res = A*B*C;
while(1)
{
if(res == 0)
{
break;
}
else if(res % 10 == 0)
{
num[0]++;
res /= 10;
}
else if(res % 10 == 1)
{
num[1]++;
res /= 10;
}
else if(res % 10 == 2)
{
num[2]++;
res /= 10;
}
else if(res % 10 == 3)
{
num[3]++;
res /= 10;
}
else if(res % 10 == 4)
{
num[4]++;
res /= 10;
}
else if(res % 10 == 5)
{
num[5]++;
res /= 10;
}
else if(res % 10 == 6)
{
num[6]++;
res /= 10;
}
else if(res % 10 == 7)
{
num[7]++;
res /= 10;
}
else if(res % 10 == 8)
{
num[8]++;
res /= 10;
}
else if(res % 10 == 9)
{
num[9]++;
res /= 10;
}
}
for(i = 0; i < 10; i++)
{
printf("%d\n",num[i]);
}
return 0;
}
A,B,C의 값을 각각 입력받고 나머지 값을 구하기 위한 코드를 작성했는데, 코드가 너무길고 효율성이 떨어진다고 판단했다.
결론적으로는 정답이었지만 코드를 다시 작성하기로 했다.
#include <stdio.h>
int main()
{
int A,B,C,i;
int num[10]={0}; //0부터 9까지의 인덱스
scanf("%d\n%d\n%d",&A,&B,&C);
int res = A*B*C;
int number = 0;
while(1)
{
number = res % 10;
if(res == 0)
{
break;
}
else
{
num[number]++;
res /= 10;
}
}
for(i = 0; i < 10; i++)
{
printf("%d\n",num[i]);
}
return 0;
}
else if 마다 들어갔던 조건문이 반복되고 있다는걸 확인했고 이전에 작성했던 코드보다 훨씬 간소화 시킨 코드를 작성했다.
아직 한번에 효율성이 높은 코드를 작성하기에는 실력이 부족하다고 생각이들지만, 계속 연습해서 더욱 효율적인 코드를 작성 할 수 있도록 해야겠다.
알고리즘 분류
- 수학
- 구현
- 사칙연산
'백준 알고리즘 코딩' 카테고리의 다른 글
[C언어] 백준 2920번 음계 (0) | 2025.03.28 |
---|---|
[C언어] 백준 10817번 세 수 (0) | 2025.03.28 |
[C언어] 백준 10250번 ACM호텔 (0) | 2025.03.27 |
[C언어] 백준 1371번 가장 많은 글자 (0) | 2025.03.27 |
[C언어] 백준 2475번 검증수 (0) | 2025.03.26 |