2학기 4주차_알고리즘( 백준2577번 : 숫자의 개수 )

2023. 10. 28. 09:31Algorithm ( p & swlug )/Baekjoon

 

 

문제

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

 

 

📌 풀이

 

위 문제를 보고 처음에 든 생각은 숫자를 연산하고 나온 결과값에서 0-9까지 해당하는 수를 각각 어떻게 저장하고 출력하느냐였다.

일단은 배열로 저장을 하고 각자리 수에서 숫자의 개수를 세야한다는 것까지는 생각을 했다.

그래서 int로 A,B,C를 각각 선언하고, 숫자를 셀 변수인 count와 각 세수의 연산결과값을 저장할 변수인 result를 선언해주었다.

그리고 result를 통해 각 세수를 곱하고 그걸 for 반복문을 활용해서 printf하도록 하였다.

 

#include <stdio.h>

int main() {
    int A, B, C;
    int result;
    int count[10] = {0};

    scanf("%d%d%d", &A, &B, &C);

    result = A * B * C;

    while (result > 0) {
        int digit = result % 10;
        count[digit]++;
        result /= 10;
    }

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

    return 0;
}

 

➡ 이 중에서 조금 고민이 많이들고 , 도움을 받았던 부분이 숫자를 세는 while 문 구간인데,

나는 결과값을 계산하기 위해 0마다 1마다 이런식으로 계산하는 방법밖에 떠오르지 않았다.

이런식으로 계산하면 분명 런타임에러가 뜰거같았고 그렇게 긴 코드문을 원할리가 없다는 생각이 들어서 고민을 많이하다가 찾아봤다.

 

📌 while 반복문을 통해서 결과값의 나머지를 digit이라는 변수에 저장하고, count해준다.

그리고 result = result/10을 통해서 반복하면서 결과값의 몫을 계산해준다.

 

 

시험기간이라 너무 오랜만에 풀었더니 헷갈리는 부분이 많았다.

요즘 알고리즘 수업을 듣는데, 수업을 듣는만큼 알고리즘 실력이 늘었으면.. 좋겠다.

while 문 안을 좀더 잘 정리해둬서 다음 부터 이정도는 스스로 고민하고 풀수있도록해야겠다.