《PHP應(yīng)用:php實(shí)現(xiàn)猴子選大王問題算法實(shí)例》要點(diǎn):
本文介紹了PHP應(yīng)用:php實(shí)現(xiàn)猴子選大王問題算法實(shí)例,希望對(duì)您有用。如果有疑問,可以聯(lián)系我們。
PHP學(xué)習(xí)本文實(shí)例講述了php實(shí)現(xiàn)猴子選大王問題算法.分享給大家供大家參考.具體分析如下:
PHP學(xué)習(xí)一、問題:
PHP學(xué)習(xí)n只猴子圍坐成一個(gè)圈,按順時(shí)針方向從1到n編號(hào).
然后從1號(hào)猴子開始沿順時(shí)針方向從1開始報(bào)數(shù),報(bào)到m的猴子出局,再從剛出局猴子的下一個(gè)位置重新開始報(bào)數(shù),
如此重復(fù),直至剩下一個(gè)猴子,它就是大王.
PHP學(xué)習(xí)設(shè)計(jì)并編寫程序,實(shí)現(xiàn)如下功能:
(1)?? 要求由用戶輸入開始時(shí)的猴子數(shù)$n、報(bào)數(shù)的最后一個(gè)數(shù)$m.
(2)?? 給出當(dāng)選猴王的初始編號(hào).
PHP學(xué)習(xí)二、解決辦法:
PHP學(xué)習(xí)
/**
* @param int $n 開始時(shí)的猴子數(shù)量
* @param int $m 報(bào)道的最后一個(gè)數(shù)
*(報(bào)到這個(gè)數(shù)的猴子被淘汰,然后下一個(gè)猴子重新從①開始報(bào)數(shù))
* @return int 猴子的初始編號(hào)
*/
function monkeySelectKing($n,$m)
{
//猴子的初始數(shù)量不能小于2
if ($n<2)
{
return false;
}
$arr=range(1,$n);
//將猴子分到一個(gè)數(shù)組里, 數(shù)組的值對(duì)應(yīng)猴子的初始編號(hào)
$unsetNum=0;
//定義一個(gè)變量,記錄猴子的報(bào)數(shù)
for ($i = 2; $i <=$n*$m ; $i++)
//總的循環(huán)次數(shù)不知道怎么計(jì)算,
{
//不過因?yàn)檠h(huán)中設(shè)置了return,所以$m*$len效率還可以
foreach ($arr as $k => $v)
{
$unsetNum++; //每到一個(gè)猴子, 猴子報(bào)數(shù)+1
//當(dāng)猴子的報(bào)數(shù)等于淘汰的數(shù)字時(shí):淘汰猴子(刪除數(shù)組元素)
//報(bào)數(shù)歸0(下一個(gè)猴子從1開始數(shù))
if ($unsetNum==$m)
{
// echo "<pre>";//打開注釋,可以看到具體的淘汰過程
// print_r($arr);
unset($arr[$k]);
//淘汰猴子
$unsetNum=0;
//報(bào)數(shù)歸零
if (count($arr)==1)
//判斷數(shù)組的長度, 如果只剩一個(gè)猴子, 返回它的值
{
return reset($arr);
}
}
}
}
}
var_dump(monkeySelectKing(6, 3));
PHP學(xué)習(xí)補(bǔ)充改進(jìn)算法(該算法更加簡潔明了!):
PHP學(xué)習(xí)
function yuesefu($n,$m) {
$r=0;
for($i=2; $i<=$n; $i++) {
$r=($r+$m)%$i;
}
return $r+1;
}
print_r(yuesefu(3,3));
PHP學(xué)習(xí)希望本文所述對(duì)大家的php程序算法設(shè)計(jì)有所贊助.
歡迎參與《PHP應(yīng)用:php實(shí)現(xiàn)猴子選大王問題算法實(shí)例》討論,分享您的想法,維易PHP學(xué)院為您提供專業(yè)教程。
轉(zhuǎn)載請(qǐng)注明本頁網(wǎng)址:
http://www.snjht.com/jiaocheng/11005.html