Tutorial PHP dan GMP: Cara mengira pembahagi sepunya terbesar dan gandaan sepunya terkecil bagi nombor besar
Pengenalan:
Dalam pengaturcaraan, kita selalunya perlu berurusan dengan pengiraan nombor besar. Walau bagaimanapun, disebabkan julat perwakilan integer yang terhad, menggunakan jenis integer tradisional akan menyebabkan masalah limpahan apabila berurusan dengan nombor yang besar. Untuk menyelesaikan masalah ini, PHP menyediakan perpustakaan sambungan GMP (GNU Multiple Precision), yang boleh mengendalikan integer yang besar secara sewenang-wenangnya. Tutorial ini menerangkan cara menggunakan sambungan GMP untuk mengira pembahagi sepunya terbesar dan gandaan sepunya terkecil bagi nombor besar, bersama-sama dengan contoh kod.
1. Pasang sambungan GMP
Untuk menggunakan sambungan GMP, anda perlu memastikan PHP telah memasang sambungan GMP. Anda boleh menyemak sama ada PHP mempunyai sambungan GMP yang dipasang melalui fungsi phpinfo(). Jika ia tidak dipasang, anda boleh memasangnya melalui langkah berikut:
function calculateGCD($a, $b) { $a = gmp_init($a); $b = gmp_init($b); return gmp_strval(gmp_gcd($a, $b)); } $a = "123456789012345678901234567890"; $b = "987654321098765432109876543210"; $gcd = calculateGCD($a, $b); echo "最大公约数:" . $gcd;
Gunakan fungsi gmp_init() untuk menukar nombor input kepada integer jenis GMP
(
fungsi gmp.toval; tukar hasil pengiraan kepada jenis Rentetan aksarafunction calculateLCM($a, $b) { $a = gmp_init($a); $b = gmp_init($b); $gcd = gmp_gcd($a, $b); return gmp_strval(gmp_mul(gmp_div($a, $gcd), $b)); } $a = "123456789012345678901234567890"; $b = "987654321098765432109876543210"; $lcm = calculateLCM($a, $b); echo "最小公倍数:" . $lcm;
Gunakan fungsi gmp_init() untuk menukar nombor input kepada integer jenis GMP
Atas ialah kandungan terperinci Tutorial PHP dan GMP: Cara Mengira Pembahagi Sepunya Terhebat dan Gandaan Sepunya Terkecil Nombor Besar. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!