>  기사  >  백엔드 개발  >  범위(1, N)에 대해 가장 컴팩트한 프라임 매핑을 결정하는 방법은 무엇입니까?

범위(1, N)에 대해 가장 컴팩트한 프라임 매핑을 결정하는 방법은 무엇입니까?

Barbara Streisand
Barbara Streisand원래의
2024-11-04 03:29:29626검색

How to Determine the Most Compact Prime Mapping for a Range (1, N)?

범위(1, N)에 대한 최적의 컴팩트 프라임 매핑 결정

가장 컴팩트한 프라임 매핑을 찾는 것은 어려운 작업일 수 있습니다. 이상적인 알고리즘은 지정된 범위(1, N)에 대해 메모리 소비가 가장 낮은 데이터 구조를 생성하는 것입니다.

한 가지 잠재적인 접근 방식은 일반 소수 테스트에서 가장 빠른 것으로 간주되는 AKS 알고리즘입니다. 큰 소수의 경우 메르센 소수와 같은 특수 형태의 소수를 탐색하는 것이 도움이 될 수 있습니다.

그러나 제한된 범위 내에서 범용 소수 테스트를 수행하려면 보다 실용적이고 효율적인 알고리즘을 사용할 수 있습니다.

<code class="python">def isprime(n):
    """Returns True if n is prime."""
    if n == 2 or n == 3:
        return True
    if n % 2 == 0 or n % 3 == 0:
        return False

    i = 5
    w = 2

    while i * i <= n:
        if n % i == 0:
            return False

        i += w
        w = 6 - w

    return True</code>

이 알고리즘은 소수(2와 3 제외)가 6k - 1 또는 6k 1 형식이라는 사실을 활용합니다. 이 알고리즘은 이 범위 내에서 제수를 효율적으로 확인하므로 소수를 결정하는 데 적합합니다.

속도가 가장 중요하고 범위가 잘 정의된 경우 페르마의 작은 정리를 기반으로 한 유사 소수 테스트를 구현하면 효율성을 더욱 높일 수 있습니다. 거짓양성(카마이클 수)을 미리 계산하고 이진 검색을 사용하면 훨씬 더 빠른 접근 방식을 얻을 수 있지만 범위가 제한됩니다.

위 내용은 범위(1, N)에 대해 가장 컴팩트한 프라임 매핑을 결정하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.