감자튀김 공장🍟

[백준/1676] 팩토리얼 0의 개수 (with 파이썬) 본문

Algorithm/BOJ

[백준/1676] 팩토리얼 0의 개수 (with 파이썬)

Potato potage 2022. 12. 24. 11:14
반응형

✔ 문제


풀이

😲 Recursion Error 코드

import sys
input = sys.stdin.readline

def factorial(x):
    if x == 1:
        return x
    return x * factorial(x-1)

n = int(input())
fac = list(map(int, str(factorial(n))))
res = 0
for i in range(len(fac) - 1, -1, -1):
    if fac[i] == 0:
        res += 1
    else:
        break
print(res)

재귀가 깊어질 때 나는 오류이다

 

👻 정답 코드

import sys
input = sys.stdin.readline

def factorial(x):
    ans = 1
    for i in range(1, x+1):
        ans *= i
    return ans

n = int(input())
fac = list(map(int, str(factorial(n))))
res = 0
for i in range(len(fac) - 1, -1, -1):
    if fac[i] == 0:
        res += 1
    else:
        break
print(res)

재귀 함수를 for문으로 해결함


✔ 설명

factorial 함수를 통해 나온 n!의 값을 map함수로 각 자리수를 나누고 이를 리스트로 만든다.

해당 리스트를 역순으로 for문을 돌면서 0이면 res += 1을, 다른 수가 나오면 break로 for문을 중단한다.


✔ 후기

재귀에서 오류가 나서 오잉 했던 문제지만 어렵지는 않았다.

찾아보니까 훨씬 더 짧게 푼 사람들도 있더라

 

👽 다른 답안

n = int(input())
count = 0

while n != 0:
    n //= 5
    count += n

print(count)
반응형
Comments