스크립트를 사용하여 PHP에서 소수 찾기
컴퓨터 과학에서 소수는 1과 자기 자신으로만 나누어지는 양의 정수를 의미합니다. 소수는 암호화, 수학적 파생, 알고리즘 최적화 등의 분야에서 사용될 수 있습니다. 실제 응용 프로그램에서 소수를 찾는 알고리즘은 매우 중요한 지식 포인트 중 하나입니다. 오늘 우리는 소수를 찾기 위해 PHP에서 스크립트를 사용하는 방법에 대해 논의하겠습니다.
- 스크리닝 방법
스크리닝 방법은 소수를 찾는 고전적인 알고리즘으로 소수가 아닌 숫자를 계속해서 걸러내고 결국 남는 것은 소수입니다. 구체적인 단계는 다음과 같습니다.
- 소수 배열 $prime = array()를 초기화하고 2부터 n까지의 숫자(n은 필수 범위)를 입력합니다.
- 숫자 2~sqrt(n)(sqrt(n)은 n의 제곱근을 나타냄)에 대해 차례로 소수인지 확인합니다. 그렇다면 소수 배열에서 배수를 제거합니다.
- 루프가 끝난 후 소수 배열에 남아 있는 숫자는 모두 소수입니다.
구현 코드는 다음과 같습니다.
function sieve($n) { $prime = array(); for($i = 2; $i <= $n; ++$i) { $prime[$i] = true; } for($i = 2; $i <= sqrt($n); ++$i) { if($prime[$i]) { for($j = $i*$i; $j <= $n; $j += $i) { $prime[$j] = false; } } } return array_keys(array_filter($prime)); }
- Fermat's Little Theorem
Fermat's Little Theorem은 숫자가 소수인지 여부를 결정하는 데 사용할 수 있는 중요한 정수론 정리입니다. 페르마의 작은 정리(Fermat's Little Theorem)는 다음과 같이 표현됩니다: p가 소수이고 a가 임의의 정수이면 a^(p-1)=1(mod p)입니다.
구체적인 단계는 다음과 같습니다.
- 숫자 a를 무작위로 선택하고 a와 n이 서로 소수인지 확인합니다. 서로 소수가 아닌 경우 false를 직접 반환합니다.
- a^(n-1) mod n의 값을 계산하고, 1이 아니면 false를 반환합니다.
- 많은 테스트를 거쳐 위의 두 조건이 충족되면 n이 소수일 가능성이 높습니다.
구현 코드는 다음과 같습니다.
function is_prime($n) { if($n <= 1) { return false; } for($i = 0; $i < 10; ++$i) { $a = rand(1, $n-1); if(gcd($a, $n) != 1) { return false; } if(mod_pow($a, $n-1, $n) != 1) { return false; } } return true; } function gcd($a, $b) { return ($b == 0) ? $a : gcd($b, $a%$b); } function mod_pow($base, $exp, $modulus) { $result = 1; while($exp > 0) { if($exp % 2 == 1) { $result = ($result * $base) % $modulus; } $exp = $exp >> 1; $base = ($base * $base) % $modulus; } return $result; }
위는 PHP에서 스크립트를 사용하여 소수를 찾는 두 가지 방법입니다. 넓은 범위의 소수를 풀 때 스크리닝 방법이 페르마의 작은 정리보다 더 효율적인 경우가 많다는 점에 유의해야 합니다.
위 내용은 스크립트를 사용하여 PHP에서 소수 찾기의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제









이 기사는 RabbitMQ 및 Redis를 사용하여 PHP에서 메시지 대기열을 구현하는 것을 자세히 설명합니다. 그것은 그들의 아키텍처 (AMQP 대 메모리), 기능 및 신뢰성 메커니즘 (확인, 트랜잭션, 지속성)을 비교합니다. 설계, 오류에 대한 모범 사례

이 기사에서는 PSR 권장 사항 (PSR-1, PSR-2, PSR-4, PSR-12)에 중점을 둔 현재 PHP 코딩 표준 및 모범 사례를 검토합니다. 일관된 스타일링, 의미있는 이름 지정 및 EFF를 통해 코드 가독성 및 유지 관리 개선을 강조합니다.

이 기사는 웹 응용 프로그램 응답 성을 향상시키기 위해 PHP에서 비동기 작업 실행을 탐구합니다. 메시지 대기열, 비동기 프레임 워크 (Reactphp, Swoole) 및 백그라운드 프로세스와 같은 방법을 자세히 설명합니다.

이 기사는 PHP의 반사 API를 설명하여 런타임 검사 및 클래스, 방법 및 속성의 조작을 가능하게합니다. 일반적인 사용 사례 (문서 생성, ORM, 종속성 주입)에 대해 자세히 설명하고 성능에 대한 경고

이 기사는 PECL에 중점을 둔 PHP 확장을 설치 및 문제 해결에 대해 자세히 설명합니다. 설치 단계 (찾기, 다운로드/컴파일, 서버 활성화, 다시 시작), 문제 해결 기술 (로그 확인, 설치 확인, 설치 확인,

PHP 8의 JIT 컴파일은 자주 실행되는 코드를 컴퓨터 코드로 컴파일하여 성능을 향상시켜 계산이 많은 응용 프로그램에 도움이되고 실행 시간을 줄입니다.

이 기사는 PHP 메모리 최적화를 다룹니다. 적절한 데이터 구조 사용, 불필요한 객체 생성을 피하고 효율적인 알고리즘을 사용하는 것과 같은 기술을 자세히 설명합니다. 공통 메모리 누출 소스 (예 : 미세한 연결, Global v

이 기사는 PHP 생태계에서 최신 상태를 유지하기위한 전략을 탐구합니다. 공식 채널, 커뮤니티 포럼, 컨퍼런스 및 오픈 소스 기부금을 강조합니다. 저자는 새로운 기능을 배우기위한 최고의 리소스와
