[11653.py] 소인수분해

DoDodo·2023년 3월 2일
0

백준

목록 보기
10/24
post-thumbnail

11653 문제 링크

문제
정수 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
  • 채점이 엄청 느리게 됨,, 왜지?
  • while에 탈출 조건 걸 수 있음

0개의 댓글