Algorithm/BOJ(Baekjoon Online Judge)
[백준 - 11653번] 소인수분해 - Java //Wello Horld//
koucop
2019. 7. 26. 14:27
이번에는 BOJ의 11653번 문제 "소인수분해" 문제를 풀어보도록 하자
매우 간단한 문제이다. 첫째 줄에 정수 N이 주어기고, 그 수를 소인수 분해해주어서, 그 결과를 한줄에 하나 씩 출력해 주면 되는 문제이다. 단, 여기에서 주의해야될 점은 N의 상한이 10,000,000(천만)으로 상당히 크다는 것을 알 수 있다. 이것을 유의해 주어서 문제를 풀어주면 된다.
성공한 코드는 아래와 같다
import java.io.*;
import java.util.*;
public class sample {
public static void main(String[] args) throws Exception {
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
BufferedWriter bw = new BufferedWriter(new OutputStreamWriter(System.out));
long N = Long.parseLong(br.readLine());
for(int i = 2; i * i <= N; i++){
if(N % i == 0){
bw.write(i + "\n");
N /= i;
i--;
}
}
if(N > 1) bw.write(N + "\n");
bw.flush();
br.close();
bw.close();
}
}
문제 : https://www.acmicpc.net/problem/11653
11653번: 소인수분해
첫째 줄에 정수 N (1 ≤ N ≤ 10,000,000)이 주어진다.
www.acmicpc.net