Post

[Bronze I] 소인수분해 - 11653

[Bronze I] 소인수분해 - 11653

문제 링크

문제 링크

성능 요약

메모리: 2020 KB, 시간: 0 ms

문제 설명

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

입력

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

출력

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

코드

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
#include <bits/stdc++.h>
using namespace std;

int main(){
    int n;
    cin >> n;
    int num=2;
    while(num*num<=n){
        if(n%num==0){
            cout << num << '\n';
            n/=num;
        }
        else{
            num++;
        }
    }
    if(n!=1)
        cout << n ;
}
This post is licensed under CC BY 4.0 by the author.