이번에는 PHP에서 무작위 제거 알고리즘을 구현하는 방법을 알려드리겠습니다. PHP에서 무작위 제거 알고리즘을 구현할 때 주의할 점은 무엇인가요? 실제 사례를 살펴보겠습니다.
<?php function getKingMokey($n, $m) { $monkey[0] = 0; //将1-n只猴子顺序编号 入数组中 for($i= 1; $i<= $n; $i++) { $monkey[$i] = $i; } $len = count($monkey); //循环遍历数组元素(猴子编号) for($i= 0; $i< $len; $i= $i) { $num = 0; foreach($monkey as $key => $value) { if($value == 0) continue; $num++; $values = $value; } //若只剩一只猴子 则输出该猴子编号(数组元素值) 并退出循环 if($num == 1) { echo $values; exit; } //将第$i只猴子踢出队伍(相应数组位置元素值设为0) $monkey[$i] = 0; //打印该猴子位置 echo $i.""; //设置计数器 for($j= 1; $j<= $m; $j++) { //猴子编号加一,遍历下一只猴子 $i++; //若该猴子未被踢出队伍,获取下一只猴子编号 if($monkey[$i] > 0) continue; //若元素值为0,则猴子已被踢出队伍,进而循环取下一只猴子编号 if($monkey[$i] == 0) { //取下一只猴子编号 for($k= $i; $k< $len; $k++) { //值为0,编号加1 if($monkey[$k] == 0) $i++; //否则,编号已取得,退出 if($monkey[$k] > 0) break; } } //若编号大于猴子个数,则从第0只猴子开始遍历(数组指针归零) //步骤同上 if($i == $len) $i = 0; //同上步骤,获取下一只猴子编号 if($monkey[$i] == 0) { for($k= $i; $k< $len; $k++) { if($monkey[$k] == 0) $i++; if($monkey[$k] > 0) break; } } } } } //猴子个数 $n = 10; //踢出队伍的编号间隔值 $m = 3; //调用猴王获取函数 getKingMokey($n, $m); ?>
실행 결과:
036927185104
재귀 알고리즘 사용
$monkeys = array(1 , 2 , 3 , 4 , 5 , 6 , 7, 8 , 9 , 10); //monkey的编号 $m = 4; //数到第几只的那只猴子被踢出去 function killMonkey($monkeys , $m , $current = 0){ $number = count($monkeys); $num = 1; if(count($monkeys) == 1){ echo $monkeys[0]."成为猴王了"; return; } else{ while($num++ < $m){ $current++ ; $current = $current%$number; } echo $monkeys[$current]."的猴子被踢掉了<br/>"; array_splice($monkeys , $current , 1); killMonkey($monkeys , $m , $current); } } killMonkey($monkeys , $m);
실행 결과:
4的猴子被踢掉了 8的猴子被踢掉了 2的猴子被踢掉了 7的猴子被踢掉了 3的猴子被踢掉了 10的猴子被踢掉了 9的猴子被踢掉了 1的猴子被踢掉了 6的猴子被踢掉了 5成为猴王了
이 기사의 사례를 읽은 후 방법을 마스터했다고 믿습니다. , 제발 다른 PHP 중국어 웹사이트 관련 기사를 주목하세요!
추천 도서:
Yii2 프레임워크 클래스 자동 로딩 사용에 대한 자세한 설명
XML을 배열 케이스로 구문 분석하는 PHP 구현에 대한 자세한 설명
위 내용은 PHP는 무작위 제거 알고리즘을 구현합니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!