관리 메뉴

솜씨좋은장씨

[Programmers] 팩토리얼 (Python) (feat.ChatGPT) 본문

Programming/코딩 1일 1문제

[Programmers] 팩토리얼 (Python) (feat.ChatGPT)

솜씨좋은장씨 2023. 4. 9. 23:22
728x90
반응형

코딩 1일 1문제! 오늘의 문제는 프로그래머스의 팩토리얼 입니다.

 

프로그래머스

코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.

programmers.co.kr

👨🏻‍💻 문제 풀이 - 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 씩 증가하면서 해당 값들을 계속 곱해가면서 비교하고 하면 됐는데...!

다음에는 한번 더 잘 생각하고 풀어봐야겠다 생각이 들었습니다.

 

읽어주셔서 감사합니다.

 

GitHub - SOMJANG/CODINGTEST_PRACTICE: 1일 1문제 since 2020.02.07

1일 1문제 since 2020.02.07. Contribute to SOMJANG/CODINGTEST_PRACTICE development by creating an account on GitHub.

github.com

Comments