[백준] 1929번: 소수 구하기 - Kotlin[코틀린]

2023. 7. 18. 03:15·알고리즘/Baekjoon

문제

 

 

1929번: 소수 구하기

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

www.acmicpc.net

 


풀이

 

 어떤 수가 소수인지 알기 위해서 아래 코드로 판별할 수 있지만, 범위 내에 모든 수를 아래와 같은 방법으로 판별한다면 비효율적이고 이 문제에서 시간초과가 발생한다.

    for(i in start .. end) {
        var cnt = 0
        for(j in 1..i) {
            if(i%j==0) {
                cnt++
            }
        }
        if(cnt==2) {
            println(i)
        }
    }

 

 대신 에라토스테네스의 체를 이용하여 해결할 수 있다. 에라토스테네스의 체는 범위 내에서 소수의 배수는 모두 지워가는 방식이다.

 

이미지 출처 - 위키백과

 

 2의 배수, 3의 배수, 5의 배수 .. 의 순서대로 소수가 아닌 수들을 지운다. 그림의 경우에 $11^2$ 이 마지막 숫자인 120보다 크기 때문에 11보다 작은 소수의 배수들만 지워도 충분하다.

 


코드

 

import kotlin.math.sqrt

fun main() {
    val br = System.`in`.bufferedReader()
    val bw = System.out.bufferedWriter()

    val sb = StringBuilder()

    val (start, end) = br.readLine().split(' ').map { it.toInt() }

    val prime = BooleanArray(end + 1)
    prime[1] = true

    for(i in 2 .. sqrt(end.toDouble()).toInt()) { // end의 제곱근보다 작은 수의 배수까지 계산
        if(prime[i]) continue

        for(j in i*i .. end step +i) { // i의 배수
            prime[j] = true
        }
    }

    for(i in start .. end) {
        if(!prime[i]) {
            sb.append(i).append('\n')
        }
    }

    bw.write("$sb")
    bw.flush()
    bw.close()
    br.close()
}

 

'알고리즘 > Baekjoon' 카테고리의 다른 글

[백준] 1181번: 단어 정렬 - Kotlin[코틀린]  (0) 2023.07.19
[백준] 1003번: 피보나치 함수 - Kotlin[코틀린]  (0) 2023.07.19
[백준] 2751번: 수 정렬하기 2 - Kotlin[코틀린]  (0) 2023.07.17
[백준] 1463번: 1로 만들기 - Kotlin[코틀린]  (0) 2023.07.17
[백준] 1316번: 그룹 단어 체커 - Kotlin[코틀린]  (0) 2023.07.17
'알고리즘/Baekjoon' 카테고리의 다른 글
  • [백준] 1181번: 단어 정렬 - Kotlin[코틀린]
  • [백준] 1003번: 피보나치 함수 - Kotlin[코틀린]
  • [백준] 2751번: 수 정렬하기 2 - Kotlin[코틀린]
  • [백준] 1463번: 1로 만들기 - Kotlin[코틀린]
junghoooooon
junghoooooon
  • junghoooooon
    코드팁스
    junghoooooon
  • 전체
    오늘
    어제
    • 전체 (120)
      • 안드로이드 (0)
        • 코드팁스 (0)
      • 유니티 (0)
        • 코드팁스 (0)
      • 알고리즘 (118)
        • 알고리즘 (0)
        • Baekjoon (118)
      • GitHub (0)
      • 티스토리 (2)
  • 블로그 메뉴

    • 링크

    • 공지사항

    • 인기 글

    • 태그

      프림
      분리집합
      정렬
      큐
      누적 합
      재귀
      크루스칼
      에라토스테네스의 체
      분할 정복
      이분 탐색
      피보나치
      우선순위 큐
      구현
      그리디
      티스토리
      BFS
      수학
      문자열
      스택
      모듈러 곱셈 역원
      dfs
      DP
      투 포인터
      브루트포스
      그래프이론
      그래프 탐색
      소수 판정
      백트래킹
      유니온파인드
      MST
    • hELLO· Designed By정상우.v4.10.2
    junghoooooon
    [백준] 1929번: 소수 구하기 - Kotlin[코틀린]
    상단으로

    티스토리툴바