11653번 : 소인수분해 - Python

Pobi·2023년 3월 21일
0

PS

목록 보기
46/107

문제

https://www.acmicpc.net/problem/11653

풀이

에라토스테네스의 체로 n까지의 소수를 구한 다음 가장 낮은 소수부터 나누어 떨어지면 출력하고 다시 그 소수로 나눠보는 방법을 사용했다.

코드

from sys import stdin

input = stdin.readline

#에라토스테네스의 체를 이용하여 n까지의 소수를 구하는 함수이다.
def prime_list(n):
    sieve = [False, False] + [True] * (n-1)

    m = int(n**0.5)
    for i in range(2, m+1):
        if sieve[i]:
            for j in range(i+i, n+1, i):
                sieve[j] = False

    return [i for i in range(2,n+1) if sieve[i]==True]


n = int(input())

prime = prime_list(n)
i=0
while(n!=1):#n이 1이면 끝나는 반복문
    if n%prime[i]==0:#n이 i번째 소수로 나누어 떨어진다면 
        print(prime[i])#i번째 소수를 출력하고
        n/=prime[i]#n은 i번째 소수로 나는 값을 갖는다.
    else:#n이 i번째 소수로 나누어 떨어지지 않는다면 
        i+=1 #i+1번째 소수로 확인한다.

다른 풀이

어차피 가장 작은 소수는 2이고, 2로 계속 나누다 보면 2의 배수로는 나눌 수 없어질 것이다. 그러면 다음 소수인 3으로 나누게 된다. 굳이 소수를 구하지 않아도, 2부터 계속 나누면 소인수 분해를 할 수 있다.

다른 코드

from sys import stdin

input = stdin.readline

n = int(input())
i = 2
while n!=1:
    if n%i == 0:
        print(i)
        n = n/i
    else:
        i+=1
        #그냥 2부터 나누어도 2의 배수로 다 나누고 못 나누는 수를 넘기기 때문에 2부터 나눠도 소수부터 나눈 것과 같은 효과가 있다.
profile
꿈 많은 개발자

0개의 댓글