溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

PHP中怎么獲取給定兩數(shù)間的最大公因數(shù)

發(fā)布時(shí)間:2021-08-13 17:25:52 來源:億速云 閱讀:168 作者:Leah 欄目:編程語言

本篇文章給大家分享的是有關(guān)PHP中怎么獲取給定兩數(shù)間的最大公因數(shù),小編覺得挺實(shí)用的,因此分享給大家學(xué)習(xí),希望大家閱讀完這篇文章后可以有所收獲,話不多說,跟著小編一起來看看吧。

實(shí)現(xiàn)步驟:有兩個(gè)變量a,b

  • 第一步:要確保大數(shù)放a中、小數(shù)放b中。

    這就需要使用if語句來判斷,如果 a < b,就定義一個(gè)中間變量temp,實(shí)現(xiàn) a與b值的交換

if ($a < $b) { //a < b,則交換兩個(gè)數(shù)
	$temp = $a;
	$a = $b;
	$b = $temp;
}
  • 第二步:求 a/b 的余數(shù),值賦給 r

$r = $a % $b;
  • 第三步:判斷 余數(shù)r 是否為0。

    如果 r=0,則上面的b就是最大公約數(shù);如果 r!=0,就需要把b的值賦給a,r的值賦給b,繼續(xù)求 a/b 的余數(shù),判斷 余數(shù)r 是否為0。這就需要利用到循環(huán)(這里使用while循環(huán)):

while ($r != 0) {
		$a = $b;
		$b = $r;
		$r = $a % $b;
	}
  • 第四步:就是輸出最大公因數(shù)b。

下面看看實(shí)現(xiàn)代碼:

<?php
header("Content-type:text/html;charset=utf-8");
function gcd($a, $b) {
	$a1 = $a;
	$b1 = $b;
	if ($a < $b)//a < b,則交換兩個(gè)數(shù)
	{
		$temp = $a;
		$a = $b;
		$b = $temp;
	}

	$r = $a % $b;
	while ($r != 0) {
		$a = $b;
		$b = $r;
		$r = $a % $b;
	}
	echo "數(shù)$a1 和$b1 的最大公因數(shù)為: $b  <br><br>";
}

gcd(30, 40);
gcd(12, 16);
gcd(15, 12);
?>

輸出結(jié)果:

PHP中怎么獲取給定兩數(shù)間的最大公因數(shù)

以上就是PHP中怎么獲取給定兩數(shù)間的最大公因數(shù),小編相信有部分知識(shí)點(diǎn)可能是我們?nèi)粘9ぷ鲿?huì)見到或用到的。希望你能通過這篇文章學(xué)到更多知識(shí)。更多詳情敬請關(guān)注億速云行業(yè)資訊頻道。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

php
AI