코딩 정복 가즈아~
Home
  • 분류 전체보기 (159)
    • 알고리즘 풀이 (149)
      • 프로그래머스 (89)
      • 백준 (59)
    • 취준 일기 (6)
    • 네트워크 정리 (1)
Home
  • 분류 전체보기 (159)
    • 알고리즘 풀이 (149)
      • 프로그래머스 (89)
      • 백준 (59)
    • 취준 일기 (6)
    • 네트워크 정리 (1)
블로그 내 검색

코딩 정복 가즈아~

(っ◔◡◔)っ ♥ 2021 취뽀하자!! ♥

  • 알고리즘 풀이/프로그래머스

    [level1] 프로그래머스 - 소수만들기(JAVA)

    2021. 8. 25.

    by. 데롱디롱

    728x90

    - 전역변수로 Eratos[]라는 소수인지를 저장할 배열을 만들어 두었다. => 에라토스테네스체 

    에라테네스의 체의 원리는 다음과 같다.

    - 2부터 소수를 구하고자 하는 구간의 모든 수를 나열
    - 2는 소수이므로 소수처리
    - 남아있는 수에서 자기 자신을 제외한 2의 배수를 모두 지움
    - 남아있는 수 가운데 3은 소수이므로 소수 처리 후 3의 배수를 모두 지움
    - 남아있는 수 가운데 5은 소수이므로 소수 처리 후 5의 배수를 모두 지움

    위의 과정들을 반복하면 구하는 구간의 모든 소수가 남는다. 1~n 구간의 소수를 찾고 싶은 경우, t^2>n을 만족하는 t보다 작은 배수만 지워도 됨

      ex) 1~120이면, 11^2>120 이므로, 11보다 작은 수 배수들만 처리해주면 됨

    t보다 작은 배수를 지우고 남은 수는 모두 소수!!

     

     

    - 조합(combination)함수에서 숫자 3가지를 선택한 후, 

       그 세 수의 합(sum)이 Eratos에 true인지를 확인 하여 answer을 증가시켜주었다.

     

     

    package com.pro.level1;
    import java.util.Arrays;
    public class 소수만들기 {
    public static void main(String[] args) {
    int[] nums = { 1, 2, 7, 6, 4 };
    System.out.println(solution(nums));
    }
    static int answer;
    static boolean Eratos[];
    public static int solution(int[] nums) {
    // 소수인 것 찾기 => 에라토스테네스의 체
    Eratos = new boolean[3001];
    Arrays.fill(Eratos, true); // 일단 모두 소수라고 해두고
    for (int i = 2; i * i <= 3000; i++) {
    if (Eratos[i])
    for (int j = i * i; j <= 3000; j += i)
    Eratos[j] = false; // 아닌 것을 하나씩 지운다.
    }
    combination(0, 0, 0, nums);
    return answer;
    }
    // 3개씩 고르는 경우의 수
    private static void combination(int cnt, int cur, int sum, int[] nums) {
    if (cnt == 3) {
    if (Eratos[sum] == true)
    answer++;
    return;
    }
    for (int i = cur; i < nums.length; i++) {
    combination(cnt + 1, i + 1, nums[i] + sum, nums);
    }
    }
    }
    profile
    데롱디롱

    희희.. (๑′ᴗ‵๑)

    저작자표시 (새창열림)

    '알고리즘 풀이 > 프로그래머스' 카테고리의 다른 글

    [level1] 프로그래머스 - 음양더하기(JAVA)  (0) 2021.08.25
    [level1] 프로그래머스 - 내적(JAVA)  (0) 2021.08.25
    [level1] 프로그래머스 - 로또의 최고순위와 최저순위(JAVA)  (0) 2021.08.25
    [level1] 프로그래머스 - 숫자 문자열과 영단어(JAVA)  (0) 2021.08.25
    [level1] 프로그래머스 - 신규 아이디 추천(JAVA)  (0) 2021.08.25

    댓글

    관련글

    • [level1] 프로그래머스 - 음양더하기(JAVA) 2021.08.25
    • [level1] 프로그래머스 - 내적(JAVA) 2021.08.25
    • [level1] 프로그래머스 - 로또의 최고순위와 최저순위(JAVA) 2021.08.25
    • [level1] 프로그래머스 - 숫자 문자열과 영단어(JAVA) 2021.08.25
    맨 위로
전체 글 보기
Tistory 로그인
Tistory 로그아웃
로그아웃 글쓰기 관리

Today

Total

피할 수 없다면, 순간을 즐겨라

Designed by Nana
블로그 이미지
데롱디롱
희희.. (๑′ᴗ‵๑)

티스토리툴바

단축키

내 블로그

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

블로그 게시글

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

모든 영역

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

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