php實現猴子選大王問題演算法執行個體_php技巧

來源:互聯網
上載者:User

本文執行個體講述了php實現猴子選大王問題演算法。分享給大家供大家參考。具體分析如下:

一、問題:

n只猴子圍坐成一個圈,按順時針方向從1到n編號。
然後從1號猴子開始沿順時針方向從1開始報數,報到m的猴子出局,再從剛出局猴子的下一個位置重新開始報數,
如此重複,直至剩下一個猴子,它就是大王。

設計並編寫程式,實現如下功能:
(1)   要求由使用者輸入開始時的猴子數$n、報數的最後一個數$m。
(2)   給出當選猴王的初始編號。

二、解決方案:

/** * @param int $n 開始時的猴子數量 * @param int $m 報道的最後一個數 *(報到這個數的猴子被淘汰,然後下一個猴子重新從①開始報數)  * @return int 猴子的初始編號  */function monkeySelectKing($n,$m){ //猴子的初始數量不能小於2 if ($n<2) { return false; }  $arr=range(1,$n); //將猴子分到一個數組裡, 數組的值對應猴子的初始編號 $unsetNum=0; //定義一個變數,記錄猴子的報數  for ($i = 2; $i <=$n*$m ; $i++) //總的迴圈次數不知道怎麼計算, { //不過因為迴圈中設定了return,所以$m*$len效率還可以 foreach ($arr as $k => $v) {  $unsetNum++; //每到一個猴子, 猴子報數+1  //當猴子的報數等於淘汰的數字時:淘汰猴子(刪除數組元素) //報數歸0(下一個猴子從1開始數)  if ($unsetNum==$m)   {//  echo "<pre>";//開啟注釋,可以看到具體的淘汰過程//  print_r($arr);  unset($arr[$k]); //淘汰猴子    $unsetNum=0; //報數歸零  if (count($arr)==1) //判斷數組的長度, 如果只剩一個猴子, 返回它的值  {   return reset($arr);  }  } } }} var_dump(monkeySelectKing(6, 3));

補充改進演算法(該演算法更加簡潔明了!):

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程式演算法設計有所協助。

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.