[백준] 2577번 숫자의 개수 파이썬

그린·2023년 3월 2일
0

백준

목록 보기
16/44
post-thumbnail
post-custom-banner

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


✔️풀이

🙋‍♀️내 풀이

a=int(input())
b=int(input())
c=int(input())

result = a*b*c
dict={}
for k in range(0, 10):
  dict[str(k)] = 0
for i in str(result):
  dict[i] += 1
for v in dict.values():
  print(v)
  1. 숫자 3개를 입력받아서 곱한다.
  2. 딕셔너리에 0부터 9까지의 키를 넣고 값을 0으로 초기화한다.
  3. key값을 만나면 값을 1 증가시켜 숫자가 나온 횟수를 표현한다.

딕셔너리를 이용하는 것보다 키값이 배열의 인덱스와 같은 것을 이용하여 배열로도 풀이했다.

a=int(input())
b=int(input())
c=int(input())

result = a*b*c
arr=[0]*10
for i in str(result):
  arr[int(i)] += 1
for a in arr:
    print(a)

배열을 이용해 풀이한 것이 딕셔너리를 이용해서 풀이한 것보다 큰 차이는 아니지만 더 오래 걸렸다.

🤔다른 사람의 풀이

b = int(input()) * int(input()) * int(input())

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

0부터 9까지의 개수를 세는 것으로 간단히 풀이했다.

post-custom-banner

0개의 댓글