Park DJ
dj0998
Park DJ
전체 방문자
오늘
어제
  • 분류 전체보기 (363)
    • 백준 (363)

공지사항

인기 글

태그

  • 백준 7567
  • 백준 2591
  • 백준 8892
  • 백준 12605
  • 백준 1064
  • 백준 2467
  • Java
  • 백준 10709
  • 백준 14582
  • 백준 1914
  • 백준 2343
  • 백준 3049
  • 백준 1495
  • 백준 2225
  • 백준 1011
  • 백준 3135
  • 백준 15961
  • 자바
  • 백준 15655
  • 백준 7662
  • 백준 4659
  • 백준 12871
  • 백준 15312
  • 백준 16194
  • 백준 6550
  • 백준 1747
  • 백준
  • 백준 1531
  • 백준 16926
  • 백준 24039
hELLO · Designed By 정상우.
Park DJ
백준

백준 9020 골드바흐의 추측(Java)

백준 9020 골드바흐의 추측(Java)
백준

백준 9020 골드바흐의 추측(Java)

2023. 2. 6. 15:06

https://www.acmicpc.net/problem/9020

 

9020번: 골드바흐의 추측

1보다 큰 자연수 중에서  1과 자기 자신을 제외한 약수가 없는 자연수를 소수라고 한다. 예를 들어, 5는 1과 5를 제외한 약수가 없기 때문에 소수이다. 하지만, 6은 6 = 2 × 3 이기 때문에 소수가 아

www.acmicpc.net


 

해석 및 팁

 


 

이 문제는 에라토스테네스의 채를 활용하면 되는 문제입니다. 먼저 n보다 작은 소수를 에라토스테네스의 채를 활용하여 구해준 후 주어진 n을 반으로 나누어서 둘 다 소수가 될 때까지 더하거나 빼주면 되는 문제입니다.

 


 

Java 코드

 


import java.util.Scanner;

public class Main {

  static int n;
  static boolean[] arr = new boolean[10001];

  public static void main(String[] args) {
    Scanner sc = new Scanner(System.in);
    StringBuilder sb = new StringBuilder();
    
    arr[0] = true;
    arr[1] = true;

    int t = sc.nextInt();
   
    for(int i = 0; i < t; i++) {
      n = sc.nextInt();
      int div = n / 2;
      demical();

      while(true) {
        if(arr[div] == false && arr[n - div] == false) break;
        div++;
      }
      
      sb.append((n - div)+" "+div).append("\n");
    }
    
    System.out.println(sb);
  }

  static void demical() {
    for(int i = 2; i <= Math.sqrt(n); i++) {
      if(arr[i] == true) continue;
      for(int j = i * i; j <= n; j += i) arr[j] = true;
    }
  }
  
}

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

백준 14889 스타트와 링크(Java)  (0) 2023.02.07
백준 1654 랜선 자르기(Java)  (0) 2023.02.06
백준 1541 잃어버린 괄호(Java)  (0) 2023.02.06
백준 2805 나무 자르기(Java)  (0) 2023.02.06
백준 11724 연결 요소의 개수(Java)  (1) 2023.02.06
    '백준' 카테고리의 다른 글
    • 백준 14889 스타트와 링크(Java)
    • 백준 1654 랜선 자르기(Java)
    • 백준 1541 잃어버린 괄호(Java)
    • 백준 2805 나무 자르기(Java)
    Park DJ
    Park DJ

    티스토리툴바

    단축키

    내 블로그

    내 블로그 - 관리자 홈 전환
    Q
    Q
    새 글 쓰기
    W
    W

    블로그 게시글

    글 수정 (권한 있는 경우)
    E
    E
    댓글 영역으로 이동
    C
    C

    모든 영역

    이 페이지의 URL 복사
    S
    S
    맨 위로 이동
    T
    T
    티스토리 홈 이동
    H
    H
    단축키 안내
    Shift + /
    ⇧ + /

    * 단축키는 한글/영문 대소문자로 이용 가능하며, 티스토리 기본 도메인에서만 동작합니다.