国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發 > PHP > 正文

php實現猴子選大王問題算法實例

2024-05-04 23:34:32
字體:
來源:轉載
供稿:網友

這篇文章主要介紹了php實現猴子選大王問題算法,實例分析了算法的原理與解決方法,具有一定參考借鑒價值,需要的朋友可以參考下

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

一、問題:

n只猴子圍坐成一個圈,按順時針方向從1到n編號。

然后從1號猴子開始沿順時針方向從1開始報數,報到m的猴子出局,再從剛出局猴子的下一個位置重新開始報數,

如此重復,直至剩下一個猴子,它就是大王。

設計并編寫程序,實現如下功能:

(1) 要求由用戶輸入開始時的猴子數$n、報數的最后一個數$m。

(2) 給出當選猴王的初始編號。

二、解決方法:

 

 
  1. /** 
  2. * @param int $n 開始時的猴子數量 
  3. * @param int $m 報道的最后一個數 
  4. *(報到這個數的猴子被淘汰,然后下一個猴子重新從①開始報數)  
  5. * @return int 猴子的初始編號  
  6. */ 
  7. function monkeySelectKing($n,$m
  8. //猴子的初始數量不能小于2 
  9. if ($n<2) 
  10. return false; 
  11.  
  12. $arr=range(1,$n); 
  13. //將猴子分到一個數組里, 數組的值對應猴子的初始編號 
  14. $unsetNum=0; 
  15. //定義一個變量,記錄猴子的報數 
  16.  
  17. for ($i = 2; $i <=$n*$m ; $i++) 
  18. //總的循環次數不知道怎么計算, 
  19. //不過因為循環中設置了return,所以$m*$len效率還可以 
  20. foreach ($arr as $k => $v
  21. $unsetNum++; //每到一個猴子, 猴子報數+1 
  22.  
  23. //當猴子的報數等于淘汰的數字時:淘汰猴子(刪除數組元素) 
  24. //報數歸0(下一個猴子從1開始數) 
  25. if ($unsetNum==$m)  
  26. // echo "<pre>";//打開注釋,可以看到具體的淘汰過程 
  27. // print_r($arr); 
  28. unset($arr[$k]); 
  29. //淘汰猴子  
  30. $unsetNum=0; 
  31. //報數歸零 
  32. if (count($arr)==1) 
  33. //判斷數組的長度, 如果只剩一個猴子, 返回它的值 
  34. return reset($arr); 
  35.  
  36. var_dump(monkeySelectKing(6, 3)); 

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

 

 
  1. function yuesefu($n,$m) {  
  2. $r=0;  
  3. for($i=2; $i<=$n$i++) { 
  4.  
  5. $r=($r+$m)%$i;  
  6. return $r+1;  
  7. }  
  8. print_r(yuesefu(3,3)); 

希望本文所述對大家的php程序算法設計有所幫助。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 乌恰县| 四子王旗| 铁岭市| 泰州市| 麟游县| 泰和县| 吴旗县| 积石山| 盐源县| 阿荣旗| 丰镇市| 稷山县| 金秀| 焉耆| 金沙县| 西藏| 高尔夫| 余庆县| 隆化县| 湟中县| 莱阳市| 阿合奇县| 乳源| 胶南市| 浪卡子县| 德昌县| 渝中区| 繁峙县| 沙雅县| 五常市| 封开县| 泗洪县| 滦平县| 大姚县| 涪陵区| 中西区| 仙桃市| 铜川市| 恭城| 甘孜县| 榆中县|