-
[백준 - 11653번] 소인수분해 - Java //Wello Horld//Algorithm/BOJ(Baekjoon Online Judge) 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
'Algorithm > BOJ(Baekjoon Online Judge)' 카테고리의 다른 글
[백준 - 1927번] 최소 힙 - Java //Wello Horld// (0) 2019.07.26 [백준 - 7579번] 앱 - Java //Wello Horld// (0) 2019.07.26 [백준 - 1018번] 체스판 다시 칠하기 - Java //Wello Horld// (0) 2019.07.26 [백준 - 2164번] 카드2 - Java //Wello Horld// (0) 2019.07.26 [백준 - 1708번] 볼록 껍질 - Java //Wello Horld// (1) 2019.07.26