본문 바로가기

코딩/백준

[백준] [Bronze I] 소인수분해 - 11653번 파이썬 문제풀이

728x90
반응형

문제 링크

성능 요약

메모리: 31120 KB, 시간: 1316 ms

분류

수학, 정수론, 소수 판정

 

문제 설명

정수 N이 주어졌을 때, 소인수분해하는 프로그램을 작성하시오.

입력

첫째 줄에 정수 N (1 ≤ N ≤ 10,000,000)이 주어진다.

출력

N의 소인수분해 결과를 한 줄에 하나씩 오름차순으로 출력한다. N이 1인 경우 아무것도 출력하지 않는다.

 

예제 입력 1 복사

72

예제 출력 1 복사

2
2
2
3
3

예제 입력 2 복사

3

예제 출력 2 복사

3

예제 입력 3 복사

6

예제 출력 3 복사

2
3

예제 입력 4 복사

2

예제 출력 4 복사

2

예제 입력 5 복사

9991

예제 출력 5 복사

97
103

 

<풀이>

import sys
input = sys.stdin.readline
N = int(input().strip())

k = 2

while N>1:
    if N%k ==0:
        
        while N%k == 0:
            print(k)
            N//=k
    k+=1

 

반응형