Study/Baekjoon

Baekjoon11653: 소인수분해

devyoseph 2021. 10. 13. 10:31

문제

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

입력

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

출력

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

 

추상화
단순하게 값을 받고 2보다 큰 수부터 차례로 나눠주는 방식을 사용했다
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));
	 int N = Integer.parseInt(br.readLine());
	 for(int i =2; i<=N; i++) {
		 while(N%i ==0) {
			 N = N/i;
			 bw.write(i+"\n");
		 }
		 if(N==1) {
			 break;
		 }
	 }
	 bw.flush();
	 bw.close();
}
}

'Study > Baekjoon' 카테고리의 다른 글

Baekjoon4948: 베르트랑 공준  (0) 2021.10.13
Baekjoon1929: 소수 구하기  (0) 2021.10.13
Baekjoon2581: 소수  (0) 2021.10.13
Baekjoon1978: 소수 찾기  (0) 2021.10.13
Baekjoon10757: 큰 수 A + B  (0) 2021.10.13