首页 > 其他 > 详细

一群猴子排成一圈,按1 2 3 ... n依次编号

时间:2020-01-13 09:25:06      阅读:158      评论:0      收藏:0      [点我收藏+]
<?php
/**
 * 一群猴子排成一圈,按1 2 3 ... n依次编号
 * 然后从第一只开始数,数到第m只把它踢出去,从它后面数,再到m只,然后踢出去。直到最后一个猴子,为大王。
 * 请算出大王的编号。
 */
function getKing($m,$n) {
    // 初始化数据
    $arr = [];
    for($i = 1;$i<= $n ;$i++) {
        $arr[] = $i;
    }

    // 循环次数,数组模拟队列
    for($j = 1;$j <= ($n-1)*$m;$j++) {
        $item = array_shift($arr); // 头一个出队列
        if ($j % $m != 0) {
            array_push($arr,$item); // 然后到队尾
        }
    }

    return array_shift($arr);
}

echo getKing(3,5); // 4

一群猴子排成一圈,按1 2 3 ... n依次编号

原文:https://www.cnblogs.com/jiqing9006/p/12185427.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!