


Gunakan skrip untuk mencari nombor perdana dalam php
Dalam sains komputer, nombor perdana merujuk kepada integer positif yang hanya boleh dibahagi dengan 1 dan dirinya sendiri. Nombor perdana boleh digunakan dalam bidang seperti penyulitan, terbitan matematik dan pengoptimuman algoritma. Dalam aplikasi praktikal, algoritma untuk mencari nombor perdana juga merupakan salah satu titik pengetahuan yang sangat penting Hari ini kita akan membincangkan cara menggunakan skrip dalam PHP untuk mencari nombor perdana.
- Kaedah menapis
Kaedah menapis ialah algoritma klasik untuk mencari nombor perdana ialah untuk terus menapis nombor yang bukan nombor perdana dan apakah itu yang tinggal pada akhirnya ialah nombor perdana. Langkah-langkah khusus adalah seperti berikut:
- Memulakan tatasusunan nombor perdana $prime = array(), dan letakkan nombor dari 2 hingga n (n ialah julat yang diperlukan) ke dalamnya.
- Untuk nombor 2~sqrt(n) (sqrt(n) mewakili punca kuasa dua bagi n), tentukan sama ada ia adalah nombor perdana secara bergilir-gilir.
- Selepas gelung tamat, baki nombor dalam tatasusunan perdana ialah semua nombor perdana.
Kod pelaksanaan adalah seperti berikut:
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)); }
- Teorem Kecil Fermat
Teorem Kecil Fermat ialah teorem teori nombor penting yang boleh digunakan Menentukan sama ada suatu nombor adalah perdana. Teorem Kecil Fermat dinyatakan seperti berikut: Jika p ialah nombor perdana dan a ialah sebarang integer, maka a^(p-1)≡1(mod p).
Langkah-langkah khusus adalah seperti berikut:
- Pilih nombor a secara rawak dan tentukan sama ada a dan n adalah perdana bersama Jika mereka tidak saling perdana, kembalikan palsu secara langsung.
- Kira nilai a^(n-1) mod n, jika tidak sama dengan 1, kembalikan palsu.
- Selepas banyak ujian, jika dua syarat di atas dipenuhi, maka n berkemungkinan menjadi nombor perdana.
Kod pelaksanaan adalah seperti berikut:
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; }
Di atas ialah dua kaedah mencari nombor perdana menggunakan skrip dalam PHP. Perlu diingatkan bahawa kaedah saringan selalunya lebih cekap daripada Teorem Kecil Fermat apabila menyelesaikan julat besar nombor perdana.
Atas ialah kandungan terperinci Gunakan skrip untuk mencari nombor perdana dalam php. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

AI Hentai Generator
Menjana ai hentai secara percuma.

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas



Artikel ini mengkaji piawaian pengekodan PHP semasa dan amalan terbaik, memberi tumpuan kepada cadangan PSR (PSR-1, PSR-2, PSR-4, PSR-12). Ia menekankan peningkatan kebolehbacaan dan kebolehkerjaan kod melalui gaya yang konsisten, penamaan bermakna, dan EFF

Butiran artikel ini melaksanakan beratur mesej dalam PHP menggunakan RabbitMQ dan Redis. Ia membandingkan seni bina mereka (AMQP vs dalam memori), ciri-ciri, dan mekanisme kebolehpercayaan (pengesahan, urus niaga, kegigihan). Amalan terbaik untuk reka bentuk, kesilapan

Butiran artikel ini memasang dan menyelesaikan masalah PHP, memberi tumpuan kepada PECL. Ia meliputi langkah pemasangan (mencari, memuat turun/menyusun, membolehkan, memulakan semula pelayan), teknik penyelesaian masalah (memeriksa log, mengesahkan pemasangan,

Artikel ini menerangkan API Refleksi PHP, membolehkan pemeriksaan runtime dan manipulasi kelas, kaedah, dan sifat. IT memperincikan kes penggunaan biasa (penjanaan dokumentasi, ORM, suntikan pergantungan) dan memberi amaran terhadap prestasi overhea

Kompilasi JIT Php 8 meningkatkan prestasi dengan menyusun kod yang sering dilaksanakan ke dalam kod mesin, memberi manfaat kepada aplikasi dengan pengiraan berat dan mengurangkan masa pelaksanaan.

Artikel ini meneroka pelaksanaan tugas tak segerak dalam PHP untuk meningkatkan respons aplikasi web. Ia memperincikan kaedah seperti beratur mesej, rangka kerja asynchronous (reactphp, swoole), dan proses latar belakang, menekankan amalan terbaik untuk kecekapan

Artikel ini meneroka strategi untuk kekal semasa dalam ekosistem PHP. Ia menekankan penggunaan saluran rasmi, forum komuniti, persidangan, dan sumbangan sumber terbuka. Penulis menyoroti sumber terbaik untuk mempelajari ciri -ciri baru dan a

Artikel ini menangani pengoptimuman memori PHP. IT memperincikan teknik seperti menggunakan struktur data yang sesuai, mengelakkan penciptaan objek yang tidak perlu, dan menggunakan algoritma yang cekap. Sumber kebocoran memori biasa (mis., Sambungan yang tidak terkawal, global v
