11653번: 소인수분해
첫째 줄에 정수 N (1 ≤ N ≤ 10,000,000)이 주어진다.
www.acmicpc.net
문제
정수 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 java.io.*;
public class Main {
public static void main(String[] args) throws IOException {
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
BufferedWriter bw = new BufferedWriter(new OutputStreamWriter(System.out));
StringBuilder sb = new StringBuilder();
int n = Integer.parseInt(br.readLine());
if(n == 1) return;
while(n != 1) {
for(int i = 2; i <= n; i++) {
if(n % i == 0) {
n /= i;
sb.append(i + "\n");
break;
}
}
}
bw.write(sb.toString());
br.close();
bw.flush();
bw.close();
}
}
그냥 소인수분해 하면 된다.
'알고리즘 문제 > 백준 온라인 저지' 카테고리의 다른 글
[BOJ] 1676 - 팩토리얼 0의 개수 JAVA (0) | 2021.01.18 |
---|---|
[BOJ] 10872 - 팩토리얼 JAVA (0) | 2021.01.18 |
[BOJ] 6588 - 골드바흐의 추측 JAVA (0) | 2021.01.16 |
[BOJ] 1929 - 소수 구하기 JAVA (0) | 2021.01.16 |
[BOJ] 1978 - 소수 찾기 JAVA (0) | 2021.01.16 |