Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
Tags
- 코드업
- C++
- 기초100제
- 파이썬
- Redux
- memory
- 협업
- react
- 타입스크립트
- 토이프로젝트
- 자료구조
- 스프링
- 일상
- Spring
- codeup
- react-redux
- 백준
- 프로그래머스
- error
- 분할메모리할당
- 정렬
- 리덕스장바구니
- web
- js to ts
- CPU 스케줄링
- Java
- 공부
- Operating System
- 알고리즘
- OS
Archives
- Today
- Total
감자튀김 공장🍟
[백준/1676] 팩토리얼 0의 개수 (with 파이썬) 본문
반응형
✔ 문제
✔ 풀이
😲 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)
반응형
'Algorithm > BOJ' 카테고리의 다른 글
[백준/15649] N과 M (1) (with 파이썬) (0) | 2022.12.26 |
---|---|
[백준/2004] 조합 0의 개수 (with 파이썬) (0) | 2022.12.25 |
[백준/9375] 패션왕 신해빈 (with 파이썬) (0) | 2022.12.23 |
[백준/1010] 다리 놓기 (with 파이썬) (0) | 2022.12.22 |
[백준/11051] 이항 계수 2 (with 파이썬) (0) | 2022.12.21 |
Comments