코딩테스트 : 숫자의 개수

juhee·2025년 7월 9일

코딩테스트

목록 보기
7/15

문제

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

예를 들어 A = 150, B = 266, C = 427이라면 A x B x C = 150 x 266 x 427 = 17037300이 되고, 계산한 결과 17037300에는 0이 3번, 1이 1번, 3이 2번, 7이 2번 쓰였다.

입력

첫째 줄에 A, 둘째 줄에 B, 셋째 줄에 C가 주어진다. A, B, C는 모두 100보다 크거나 같고, 1,000보다 작은 자연수이다.

출력

첫째줄에는 A x B x C의 결과에 0이 몇 번 쓰였는지 출력한다. 마찬가지로 둘째 줄부터 열 번째 줄까지 A x B x C의 결과에 1부터 9까지의 숫자가 각각 몇 번 쓰였는지 차례로 한 줄에 하나씩 출력한다.

제한사항

입출력 예

예제 입력 1

150
266
427

예제 출력 1

3
1
0
2
0
0
0
2
0
0

문제 유형 분류

  • 문자열 처리
  • 시뮬레이션
  • 빈도수 세기 (카운팅)

시간 복잡도 + 공간복잡도 추정

  • 시간복잡도
    • 곱셈은 O(1), 문자열 변환은 O(N) (N은 숫자 자릿수, 최대 10자리 이하)
    • 전체적으로 O(N)
  • 공간복잡도
    • O(10) → 0~9까지 개수를 저장하는 리스트

적합한 알고리즘 / 자료구조

  • 문자열 반환(str())
  • 리스트 인덱싱
  • count() 함수 or for문으로 직접 카운팅

필요한 라이브러리

  • 표준 입력 함수 (input()), 별도 외부 라이브러리 불필요

최악의 경우 시뮬레이션

  • A = B = C = 999 → 결과는 약 9자리 숫자
  • 충분히 문자열로 변환해 처리 가능

접근 방법

  1. A, B, C 입력 받기
  2. A × B × C 계산
  3. 결과를 문자열로 변환
  4. 0부터 9까지 순회하면서 .count(str(i)) 또는 직접 카운팅
  5. 각 숫자별 등장 횟수 출력

최종 코드

# 입력
A = int(input())
B = int(input())
C = int(input())

# 곱셈 결과
result = A * B * C

# 문자열로 변환
result_str = str(result)

# 0~9 숫자 카운트
for i in range(10):
    print(result_str.count(str(i)))

추가 팁

  • collections.Counter로도 가능하지만 이 문제에서는 단순한 리스트와 문자열 메서드로 충분함
  • 출력 순서에 주의 (0부터 9까지 순서대로)

0개의 댓글