>백엔드 개발 >PHP 튜토리얼 >PHP 및 GMP 튜토리얼: 큰 숫자의 오일러 감소를 계산하는 방법

PHP 및 GMP 튜토리얼: 큰 숫자의 오일러 감소를 계산하는 방법

王林
王林원래의
2023-07-30 13:09:171354검색

PHP 및 GMP 튜토리얼: 오일러의 큰 수에 대한 감소된 거듭제곱을 계산하는 방법

Euler의 totient 함수(Euler's totient function)는 정수론에서 일반적인 함수로, n보다 작거나 같은 양의 정수 n을 계산하는 데 사용됩니다. n과 상대적으로 소수인 숫자의 수입니다. 큰 숫자의 오일러 전력 감소를 계산할 때 데이터 양이 많기 때문에 일반적인 계산 방법을 직접 사용할 수 없지만 연산을 수행하려면 PHP의 GMP(GNU Multiple Precision) 확장을 사용해야 합니다. 이 기사에서는 PHP와 GMP를 사용하여 큰 숫자의 오일러 감소 거듭제곱을 계산하는 방법을 소개하고 코드 예제를 제공합니다.

  1. GMP 확장 설치
    시작하기 전에 PHP에 GMP 확장이 설치되어 있는지 확인해야 합니다. 설치되어 있지 않은 경우 아래 단계에 따라 설치할 수 있습니다.

먼저 PHP 확장 디렉터리를 확인하면 phpinfo() 함수를 실행하여 현재 PHP 구성 정보를 확인할 수 있습니다. 표시된 구성 정보에서 "extension_dir"을 찾아 확장 디렉터리의 경로를 기록합니다.

다음으로, GMP 공식 홈페이지(https://gmplib.org/)에서 GMP 라이브러리의 소스코드를 다운로드하여 로컬로 추출합니다.

명령줄 창을 열고 압축이 풀린 GMP 디렉터리를 입력하세요.

다음 명령을 실행하여 컴파일하고 설치합니다.

$ ./configure
$ make
$ make install

설치가 완료되면 컴파일된 GMP 확장 파일(보통 gmp.so 또는 gmp.dll)을 앞서 기록해 둔 확장 디렉터리에 복사합니다.

php.ini 파일을 편집하고 파일 끝에 다음 줄을 추가하세요:

extension=gmp

php.ini 파일을 저장하고 닫으세요.

새 GMP 확장을 적용하려면 웹 서버를 다시 시작하세요.

  1. 오일러의 감소된 전력 계산하기
    다음으로, PHP와 GMP를 사용하여 오일러의 감소된 전력을 계산하겠습니다. 다음은 오일러의 감소 전력을 계산하는 샘플 코드입니다.
<?php
function euler_power($base, $exponent, $modulus) {
    $result = gmp_init(1);

    while (gmp_cmp($exponent, 0) > 0) {
        if (gmp_even($exponent)) {
            $base = gmp_powm($base, 2, $modulus);
            $exponent = gmp_div_q($exponent, 2);
        } else {
            $result = gmp_mul($result, $base);
            $exponent = gmp_sub($exponent, 1);
        }
    }

    return gmp_mod($result, $modulus);
}

// 示例用法
$base = gmp_init(23456789);
$exponent = gmp_init(98765432);
$modulus = gmp_init(1234567891);

$result = euler_power($base, $exponent, $modulus);
echo gmp_strval($result);
?>

위의 예제 코드에서는 오일러의 감소 전력을 계산하기 위해 euler_power라는 함수를 정의합니다. 이 함수는 기본, 지수 및 모듈러스의 세 가지 매개변수를 허용합니다. 이 함수는 루프와 조건부 판단을 사용하여 인덱스의 패리티를 결정하고, 패리티에 따라 해당 연산을 수행하고, 최종적으로 계산 결과를 반환합니다.

사용예에서는 gmp_init 함수를 통해 밑수, 지수, 모듈러스를 GMP의 정수형으로 변환합니다. 그런 다음 euler_power 함수를 호출하여 오일러의 감소된 전력을 계산하고, gmp_strval 함수를 사용하여 계산 결과를 문자열로 변환하여 출력합니다.

참고: GMP 기능을 사용할 때 매개변수 유형은 GMP의 정수 유형이어야 하며, 그렇지 않으면 오류가 발생합니다. 따라서 변수를 정의할 때 gmp_init 함수를 사용하여 GMP의 정수형으로 변환해야 합니다.

  1. 요약
    이 글에서는 PHP와 GMP를 사용하여 큰 수의 오일러 감소 거듭제곱을 계산하는 방법을 소개합니다. GMP 확장을 설치하면 PHP에서 많은 작업을 수행하고 GMP에서 제공하는 기능을 사용하여 복잡한 작업을 완료할 수 있습니다. 샘플 코드는 오일러의 감소된 전력을 계산하는 함수를 정의하는 방법을 보여주고 참조용 사용법 예를 제공합니다. 이 기사가 독자들이 PHP와 GMP를 사용하여 큰 숫자의 오일러 감소 검정력을 계산하고 그로부터 이점을 얻는 방법을 이해하는 데 도움이 되기를 바랍니다.

위 내용은 PHP 및 GMP 튜토리얼: 큰 숫자의 오일러 감소를 계산하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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