본문 바로가기
파이썬/파이썬 알고리즘

파이썬 백준 2577번 숫자의 개수 각 숫자가 몇 번 나왔는지 저장하기 위해 일차원 배열을 만드는 문제

by Go! Jake 2021. 3. 30.

  문제

세 개의 자연수 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 for문 사용

A=int(input())
B=int(input())
C=int(input())

D=str(A*B*C)

numbers=[0,1,2,3,4,5,6,7,8,9]
counter=[0]*10

for i in D:
    for j in numbers:
        if int(i) == j:
            counter[j]+=1

for i in counter:
    print(i)

int(input())

input() 함수를 통해 각 문자열을 입력을 받고, int()를 통해 정수형으로 변환한다.

D=str(A*B*C)A*B*C 값은 연산한 후에 문자열로 변경한다.

numbers=[0,1,2,3,4,5,6,7,8,9]

0에서 9까지 선언 해 준다. 이는 추후에 각 자릿수마다 0~9까지 비교할 때 사용된다.
counter=[0]*10

0~9까지 개수를 세어야 하므로, 개수 세는 리스트를 만든다.

for i in D:
    for j in numbers:
        if int(i) == j:
            counter[j]+=1

- D는 문자열이기 때문에, 예를 들어 "23943"이라고 하면, for i in D에서 i는 각각 2,3,9,4,3 형식으로 꺼내게 된다.
- i 값은 문자열이기 때문에 int(i)로 정수형 처리 해 주고, 이를 numbers와 각각 비교할 수 있도록 for j in numbers:를 사용한다.
- 값이 일치할 때엔 counter 리스트의 index에 맞게 하나씩 더하여 각 자릿수를 센다.

for i in counter:
    print(i)
각각 0 개수부터 9의 개수까지 리스트에서 출력한다.

  풀이 - 2 count 함수 사용

A=int(input())
B=int(input())
C=int(input())

D=str(A*B*C)

D=list(D)

for i in range(10):
    print(D.count(str(i)))

D=list(D)

문자열을 리스트 선언 시 각 문자열이 요소로 저장된다.

 

for i in range(10):
    print(D.count(str(i)))

.count(str(i))를 사용하면 0에서부터 9까지 리스트 내에 존재하는 개수를 세어준다.

i는 정수형이므로 str() 문자열 처리 해준다.

 

 

  오답노트

이번 문제는 문자열 및 정수형을 맞춰주는 데에 있어서 신경써야하는 문제다. 잔실수 나오기 좋은 문제이다.

 

 

댓글