728x90
난이도 - 실버 4
문제
정수 n(0 ≤ n ≤ 4*109)가 주어졌을 때, n보다 크거나 같은 소수 중 가장 작은 소수 찾는 프로그램을 작성하시오.
입력
첫째 줄에 테스트 케이스의 개수가 주어진다. 각 테스트 케이스는 한 줄로 이루어져 있고, 정수 n이 주어진다.
출력
각각의 테스트 케이스에 대해서 n보다 크거나 같은 소수 중 가장 작은 소수를 한 줄에 하나씩 출력한다.
728x90
입력 수의 다음 소수를 찾아 출력한다. 소수를 판정하는 isPrime함수와 다음 소수를 찾는 findNextPrime함수를 만들었다.
import java.io.*;
public class Main4134 {
public static void main(String[] args) throws Exception {
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
BufferedWriter bw = new BufferedWriter(new OutputStreamWriter(System.out));
int T=Integer.parseInt(br.readLine());
StringBuffer sb=new StringBuffer();
while (T-- > 0) {
long n = Long.parseLong(br.readLine());
sb.append(findNextPrime(n)).append('\n');
}
bw.write(sb.toString());
bw.flush();
br.close();
bw.close();
}
private static long findNextPrime(long n) {
if (n <= 2) return 2;
if (n % 2 == 0) n++;
while (!isPrime(n)) {
n += 2;
}
return n;
}
private static boolean isPrime(long num) {
if (num == 3) return true;
if (num % 3 == 0) return false;
for (long i = 5; i * i <= num; i += 6) {
if (num % i == 0 || num % (i + 2) == 0) {
return false;
}
}
return true;
}
}
findNextPrime():
입력수를 findNextPrime 함수에 넣고 만약 입력값이 0이나 1인 경우 2를 출력하고 그 외 짝수인 경우 1을 더해 홀수로 만든다. 2를 제외한 다른 소수들은 홀수이기 때문에 홀수값들만 isPrime 함수로 돌려 소수인지 판정한다. isPrime이 true(소수)를 반환할때까지 while문을 돌린다.
isPrime():
우선 num이 3이면 소수이므로 true를 반환하고 아니면 3의 배수인지 확인한다. 3의 배수도 아니면 5부터 num의 제곱근까지 for문을 돌린다. 제곱근까지만 돌리는 이유는 소수가 아닌 수의 약수 중 하나는 반드시 그 수의 제곱근 이하이기 때문이다. 소수는 보통 6k ± 1의 형태이다. 때문에 5부터 시작해서 6씩 더하면 i는 5, 11, 17, ...이고 num%i==0 || num%(i+2)==0 을 확인해 num이 소수인지 확인한다.
결과 )
728x90
'백준 > Java' 카테고리의 다른 글
[백준 자바] 9372번(상근이의 여행) - BFS(너비 우선 탐색) 사용하기 (1) | 2024.04.20 |
---|---|
[백준 자바] 3052번(나머지) - 배열의 중복 요소 제거 (16) | 2024.04.07 |
[백준 자바] 2563번(색종이) - 2차원 배열 (21) | 2024.03.25 |
[백준 자바] 2295번(세 수의 합) (27) | 2024.03.19 |
[백준 자바] 2720번(세탁소 사장 동혁) (27) | 2024.03.19 |