[실버 2] 17103번 골드바흐 파티션

2023. 10. 13. 09:50·Coding Test/백준[JAVA]

문제 링크 : https://www.acmicpc.net/problem/17103

문제

골드바흐의 추측: 2보다 큰 짝수는 두 소수의 합으로 나타낼 수 있다.
짝수 N을 두 소수의 합으로 나타내는 표현을 골드바흐 파티션이라고 한다. 짝수 N이 주어졌을 때, 골드바흐 파티션의 개수를 구해보자. 두 소수의 순서만 다른 것은 같은 파티션이다.

입력

첫째 줄에 테스트 케이스의 개수 T (1 ≤ T ≤ 100)가 주어진다. 각 테스트 케이스는 한 줄로 이루어져 있고, 정수 N은 짝수이고, 2 < N ≤ 1,000,000을 만족한다.

출력

각각의 테스트 케이스마다 골드바흐 파티션의 수를 출력한다.

예제 입력 1
5
6
8
10
12
100

예제 출력 1
1
1
2
1
6

코드

import java.io.*;

public class Main {

	public static void main(String[] args) throws IOException {
		BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
		
		int T = Integer.parseInt(br.readLine());
		
		// 소수 판별
		boolean[] num = new boolean[1000001];
		num[0] = num[1] = true;
		for(int i=2; i*i<=1000000; i++) {
			if(!num[i])  // 소수이면
				for(int j=i+i; j<=1000000; j+=i) num[j] = true;  // 배수를 지움. 소수가 아니라고 표시
		}
		
		for(int i=0; i<T; i++) {
			int temp = Integer.parseInt(br.readLine());
			int result = 0; 
			
			for(int j=2; j<=temp/2; j++) {  //나누기 2 하는 이유는 (3, 5) 랑 (5, 3) 처럼 나오면 한 개로 인정되도록 하려고.
				if(!num[j] && !num[temp - j]) { // 두 값 모두 소수이면 골드바흐 파티션 성립
					result++;
				}
			}
			System.out.println(result);
		}
	}
}
저작자표시 비영리 변경금지 (새창열림)

'Coding Test > 백준[JAVA]' 카테고리의 다른 글

[브론즈 4] 24723번 녹색거탑  (0) 2023.10.13
[브론즈 4] 15439번 베라의 패션  (0) 2023.10.13
[실버 2] 4948번 베르트랑 공준  (0) 2023.10.13
[실버 3] 1929번 소수 구하기  (0) 2023.10.10
[실버 4] 4134번 다음 소수  (0) 2023.10.09
'Coding Test/백준[JAVA]' 카테고리의 다른 글
  • [브론즈 4] 24723번 녹색거탑
  • [브론즈 4] 15439번 베라의 패션
  • [실버 2] 4948번 베르트랑 공준
  • [실버 3] 1929번 소수 구하기
woojin._.
woojin._.
여러가지 개발을 해보며 발생하는 이야기들에 대한 블로그입니다:)
  • woojin._.
    Jin's Dev Story
    woojin._.
  • 전체
    오늘
    어제
    • 분류 전체보기 (829)
      • Tools (25)
        • eGovFrame (3)
        • GeoServer (3)
        • QGIS (2)
        • LabelImg (2)
        • Git (6)
        • GitHub (1)
        • Eclipse (7)
        • Visual Studio (1)
      • Web & Android (121)
        • SpringBoot (37)
        • Three.js (2)
        • Spring Data JPA (9)
        • 스프링 부트 쇼핑몰 프로젝트 with JPA (25)
        • Thymeleaf (4)
        • Spring Security (15)
        • Flutter (29)
      • Programming Language (61)
        • JAVA (27)
        • JavaScript (14)
        • Dart (2)
        • Python (15)
        • PHP (3)
      • Database (43)
        • PostgreSQL (32)
        • MYSQL (7)
        • Oracle (3)
        • MSSQL (1)
      • SERVER (17)
        • TCP_IP (3)
        • 리눅스 (7)
        • AWS (7)
      • Coding Test (445)
        • 백준[JAVA] (108)
        • 프로그래머스[JAVA] (260)
        • 알고리즘 고득점 Kit[JAVA] (3)
        • SQL 고득점 Kit[ORACLE] (74)
      • CS 지식 (49)
        • [자료구조] (14)
        • [네트워크] (12)
        • [데이터베이스] (10)
        • [알고리즘] (9)
        • [운영체제] (4)
      • 기타 (6)
      • 자격증 & 공부 (62)
        • 정보처리기사 (2)
        • SQLD (6)
        • 네트워크관리사 2급 (5)
        • 리눅스마스터 1급 (44)
        • 리눅스마스터 2급 (1)
        • ISTQB (3)
        • 시스템보안 (1)
  • 블로그 메뉴

    • 홈
    • 태그
    • 방명록
  • 인기 글

  • 태그

    백준
    CS지식
    리눅스
    스프링
    Oracle
    스프링부트
    CS
    programmers
    Flutter
    스프링 부트 쇼핑몰 프로젝트 with JPA
    시큐리티
    python
    Linux
    자바
    spring
    DB
    Java
    데이터
    데이터베이스
    postgresql
    JPA
    baekjoon
    리눅스마스터 1급
    pcce 기출문제
    backjoon
    프로그래머스
    Spring Security
    리눅스마스터
    springboot
    플러터
  • 최근 글

  • hELLO· Designed By정상우.v4.10.0
woojin._.
[실버 2] 17103번 골드바흐 파티션
상단으로

티스토리툴바