php實(shí)現(xiàn)猴子選大王問(wèn)題算法實(shí)例
本文實(shí)例講述了php實(shí)現(xiàn)猴子選大王問(wèn)題算法。分享給大家供大家參考。具體分析如下:
一、問(wèn)題:
n只猴子圍坐成一個(gè)圈,按順時(shí)針?lè)较驈?到n編號(hào)。
然后從1號(hào)猴子開(kāi)始沿順時(shí)針?lè)较驈?開(kāi)始報(bào)數(shù),報(bào)到m的猴子出局,再?gòu)膭偝鼍趾镒拥南乱粋€(gè)位置重新開(kāi)始報(bào)數(shù),
如此重復(fù),直至剩下一個(gè)猴子,它就是大王。
設(shè)計(jì)并編寫(xiě)程序,實(shí)現(xiàn)如下功能:
(1) 要求由用戶輸入開(kāi)始時(shí)的猴子數(shù)$n、報(bào)數(shù)的最后一個(gè)數(shù)$m。
(2) 給出當(dāng)選猴王的初始編號(hào)。
二、解決方法:
/** * @param int $n 開(kāi)始時(shí)的猴子數(shù)量 * @param int $m 報(bào)道的最后一個(gè)數(shù) *(報(bào)到這個(gè)數(shù)的猴子被淘汰,然后下一個(gè)猴子重新從①開(kāi)始報(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ì)算, { //不過(guò)因?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開(kāi)始數(shù)) if ($unsetNum==$m) { // echo "<pre>";//打開(kāi)注釋,可以看到具體的淘汰過(guò)程 // print_r($arr); unset($arr[$k]); //淘汰猴子 $unsetNum=0; //報(bào)數(shù)歸零 if (count($arr)==1) //判斷數(shù)組的長(zhǎng)度, 如果只剩一個(gè)猴子, 返回它的值 { return reset($arr); } } } } } var_dump(monkeySelectKing(6, 3));
補(bǔ)充改進(jìn)算法(該算法更加簡(jiǎn)潔明了?。?/p>
function yuesefu($n,$m) { $r=0; for($i=2; $i<=$n; $i++) { $r=($r+$m)%$i; } return $r+1; } print_r(yuesefu(3,3));
希望本文所述對(duì)大家的php程序算法設(shè)計(jì)有所幫助。
- PHP寫(xiě)楊輝三角實(shí)例代碼
- 深入理解PHP幾個(gè)算法:PHP冒泡、PHP二分法、PHP求素?cái)?shù)、PHP乘法表
- PHP求最大子序列和的算法實(shí)現(xiàn)
- php 3行代碼的分頁(yè)算法(求起始頁(yè)和結(jié)束頁(yè))
- PHP貪婪算法解決0-1背包問(wèn)題實(shí)例分析
- php約瑟夫問(wèn)題解決關(guān)于處死犯人的算法
- PHP基于回溯算法解決n皇后問(wèn)題的方法示例
- PHP使用棧解決約瑟夫環(huán)問(wèn)題算法示例
- PHP基于遞歸算法解決兔子生兔子問(wèn)題
- PHP實(shí)現(xiàn)的解漢諾塔問(wèn)題算法示例
- PHP實(shí)現(xiàn)的楊輝三角求解算法分析
相關(guān)文章
PHP數(shù)據(jù)庫(kù)操作四:mongodb用法分析
這篇文章主要介紹了PHP數(shù)據(jù)庫(kù)操作mongodb用法,結(jié)合實(shí)例形式較為詳細(xì)的分析了MongoDB的功能、安裝、基本命令、使用方法及相關(guān)注意事項(xiàng),需要的朋友可以參考下2017-08-08PHP GD庫(kù)生成圖像的幾個(gè)函數(shù)總結(jié)
這篇文章主要介紹了PHP GD庫(kù)生成圖像的幾個(gè)函數(shù)總結(jié),即imagegif、imagejpeg、imagepng、imagewbmp幾個(gè)生成圖片的函數(shù),需要的朋友可以參考下2014-11-11php使用自定義函數(shù)實(shí)現(xiàn)漢字分割替換功能示例
這篇文章主要介紹了php使用自定義函數(shù)實(shí)現(xiàn)漢字分割替換功能,結(jié)合實(shí)例形式分析了php針對(duì)漢字的遍歷、轉(zhuǎn)換與分割操作相關(guān)技巧,需要的朋友可以參考下2017-01-01PHP服務(wù)器頁(yè)面間跳轉(zhuǎn)實(shí)現(xiàn)方法
在ASP中,我們可以使用Server.Transfer來(lái)實(shí)現(xiàn)在服務(wù)器端重定向,PHP中雖然沒(méi)有這樣的函數(shù),但是要實(shí)現(xiàn)類(lèi)似的跳轉(zhuǎn)也不難2012-08-08php根據(jù)用戶名和手機(jī)號(hào)查詢是否存在手機(jī)號(hào)碼
本文主要分享了php根據(jù)用戶名和手機(jī)號(hào)查詢是否存在手機(jī)號(hào)碼的代碼,具有很好的參考價(jià)值,下面跟著小編一起來(lái)看下吧2017-02-02PHP刪除二維數(shù)組中相同元素及數(shù)組重復(fù)值的方法示例
這篇文章主要介紹了PHP刪除二維數(shù)組中相同元素及數(shù)組重復(fù)值的方法,涉及php針對(duì)數(shù)組的遍歷、判斷、比較等相關(guān)操作技巧,需要的朋友可以參考下2017-05-05