문제
정수 N이 주어졌을 때, 소인수분해하는 프로그램을 작성하시오.
입력
첫째 줄에 정수 N (1 ≤ N ≤ 10,000,000)이 주어진다.
출력
N의 소인수분해 결과를 한 줄에 하나씩 오름차순으로 출력한다. N이 1인 경우 아무것도 출력하지 않는다.
내 코드
N = int(input())
i = 2
while N != 1:
if N % i == 0:
print(i)
N = N/i
else:
i += 1
N = int(input())
while True:
if N == 1:
break
#2부터 계속 나누기
for i in range(2, N+1):
if N % i == 0: #나누어지는 수일때
while N % i == 0:
print(i)
N = N/i
if N == 1:
break