[Programmers] 팩토리얼 (Python) (feat.ChatGPT)
코딩 1일 1문제! 오늘의 문제는 프로그래머스의 팩토리얼 입니다.
👨🏻💻 문제 풀이 - SOMJANG
1. math 의 factorial 함수를 활용하여 팩토리얼을 구하는 함수 factorial 을 만들었습니다.
2. i = 1 부터 시작하고 while 반복문을 실행합니다.
3. 반복문 안에서 아까 만들어 둔 factorial 함수를 활용하여 팩토리얼을 구합니다.
4. 계산한 팩토리얼 값이 입력 받은 수 n 과 같아지면 반복문 종료 -> 이때의 i 를 return 합니다.
5. 계산한 팩토리얼의 값이 만약 입력 받은 수 n 보다 커지면 반복문을 종료하고 -> 이때의 i에서 -1 한 값을 정답으로 합니다.
6. while 반복문을 안에서 4번, 5번 조건에 걸리지 않았다면 i를 1 증가 시켜줍니다.
👨🏻💻 코드 (Solution)- SOMJANG
import math
def factorial(n):
return math.factorial(n)
def solution(n):
i = 1
while True:
factorial_num = factorial(n=i)
if factorial_num == n:
break
elif factorial_num > n:
i -= 1
break
i+=1
return i
👨🏻💻 문제 풀이 - ChatGPT - 1차시도 실패
아래는 Python3으로 작성한 문제 해결을 위한 코드입니다.
이 코드는 주어진 조건에 맞추어 i를 1부터 시작하고, i!이 n보다 작거나 같은 경우에만 while loop를 돌리며 i를 1씩 증가시킵니다. 이 때, i! 대신 i*(i+1)//2을 사용한 이유는 i!이 n을 넘어서면 연산이 불필요하게 반복되는 것을 막기 위해서입니다. 마지막으로, 최대 i-1!을 return 합니다.
👨🏻💻 코드 (Solution)- ChatGPT - 1차시도 실패
def solution(n):
# 0! = 1 이므로 i를 1부터 시작
i = 1
# i!이 n보다 작거나 같은 경우에만 while loop를 돌림
while (i*(i+1)//2) <= n:
i += 1
# 최대 i-1!을 return
return i-1
1차시도는 실패!
문제를 조금 잘 못 이해했는지 팩토리얼이 아니라
1 ~ n 까지 숫자의 합으로 문제를 풀어서 틀렸습니다.
팩토리얼로 해결해야하는 문제임을 알려주고 2차 시도! 를 해보았습니다.
👨🏻💻 문제 풀이 - ChatGPT - 2차시도
죄송합니다. 팩토리얼 문제로 오해하셨을 수 있습니다. 아래는 팩토리얼 문제를 해결하기 위한 Python3 코드입니다.
👨🏻💻 코드 (Solution)- ChatGPT - 2차시도
def solution(n):
i = 1
factorial = 1
while factorial <= n:
i += 1
factorial *= i
return i - 1
2차 시도는...!
딱 보고
아... 내가 너무 문제를 복잡하게 생각하고 풀었었구나 생각이 들도록하는 풀이었습니다.
아~~~~~
n팩토리얼이라함은 1 ~ n 까지의 숫자를 모두 곱한 값이었지....!
아 그냥 i 를 1부터 1 씩 증가하면서 해당 값들을 계속 곱해가면서 비교하고 하면 됐는데...!
다음에는 한번 더 잘 생각하고 풀어봐야겠다 생각이 들었습니다.
읽어주셔서 감사합니다.