반응형
01-06 12:48
Today
Total
«   2025/01   »
1 2 3 4
5 6 7 8 9 10 11
12 13 14 15 16 17 18
19 20 21 22 23 24 25
26 27 28 29 30 31
관리 메뉴

개발하는 고라니

[백준] 1929번 : 소수 구하기 본문

Programming/백준

[백준] 1929번 : 소수 구하기

조용한고라니 2021. 3. 23. 11:49
반응형
 

1929번: 소수 구하기

첫째 줄에 자연수 M과 N이 빈 칸을 사이에 두고 주어진다. (1 ≤ M ≤ N ≤ 1,000,000) M이상 N이하의 소수가 하나 이상 있는 입력만 주어진다.

www.acmicpc.net


[소수 판별]

소수를 판별하는 간단한 알고리즘은 특정 숫자 x에 대해 2 ~ x의 제곱근까지 나머지연산을 해보며 결과값이 0이면 소수가 아니라고 판별한다.

 

자바의 경우 출력이 많을 수 있으므로 System.out.println()을 이용한다면 메모리와 시간을 많이 잡아먹는다. 따라서 StringBuilder를 이용했다. 혹시 메모제이션으로 할 수도 있지 않을까 했지만 굳이 필요는 없었다.

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.StringTokenizer;

public class Main {

    static boolean isPrime(int x){
        if(x == 1) return false;

        for(int i=2; i<=Math.sqrt(x); i++)
            if(x % i == 0)
                return false;

        return true;
    }

    public static void main(String[] args) throws IOException {
        BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
        StringTokenizer st = new StringTokenizer(br.readLine());
        StringBuilder sb = new StringBuilder();

        int n = Integer.parseInt(st.nextToken());
        int m = Integer.parseInt(st.nextToken());

        for(int i=n; i<=m; i++)
            if(isPrime(i))
                sb.append(i).append('\n');

        System.out.println(sb.toString());
    }
}
반응형

'Programming > 백준' 카테고리의 다른 글

[백준] 13701번 : 중복 제거  (0) 2021.03.24
[백준] 1644번 : 소수의 연속합  (0) 2021.03.23
[백준] 1978번 : 소수 찾기  (0) 2021.03.23
[백준] 13460번 : 구슬 탈출 2  (0) 2021.03.23
[백준] 2776번 : 암기왕  (1) 2021.03.21
Comments