奶头挺立呻吟高潮av全片,成人试看120秒体验区,性欧美极品v,A片高潮抽搐揉捏奶头视频

php語言

PHP實現猴子選大王問題的算法

時間:2025-03-13 00:36:45 php語言 我要投稿
  • 相關推薦

PHP實現猴子選大王問題的算法

  我們的事業就是學習再學習,努力積累更多的知識,因為有了知識,社會就會有長足的進步,人類的未來幸福就在于此。以下是小編為大家搜索整理的PHP實現猴子選大王問題的算法,希望對大家有所幫助!更多精彩內容請及時關注我們應屆畢業生考試網!

  一、問題:

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

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

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

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

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

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

  二、解決方法:

  ?

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
/**
* @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));

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

  ?

1
2
3
4
5
6
7
8
9
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實現猴子選大王問題的算法】相關文章:

PHP實現抽獎概率算法09-13

PHP紅包算法11-04

php經典算法介紹10-05

PHP經典算法題09-05

PHP幾個經典算法題10-27

PHP的樹形結構算法07-06

如何解決PHP無法實現多線程的問題08-20

實現PHP實現限制IP訪問11-11

PHP 快速排序算法解析06-11

主站蜘蛛池模板: 桂平市| 厦门市| 施秉县| 玉屏| 甘谷县| 乡城县| 界首市| 桐乡市| 昭觉县| 临湘市| 宝山区| 法库县| 五峰| 东乌珠穆沁旗| 县级市| 辛集市| 湾仔区| 蚌埠市| 和平县| 华亭县| 江安县| 牟定县| 拜泉县| 沧源| 建昌县| 公主岭市| 巴南区| 鞍山市| 凯里市| 新蔡县| 襄城县| 珲春市| 枞阳县| 堆龙德庆县| 保定市| 沙田区| 开江县| 郧西县| 九江市| 库车县| 三亚市|