PHP实现的猴王算法(猴子选大王)示例


Posted in PHP onApril 30, 2018

本文实例讲述了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程序设计有所帮助。

PHP 相关文章推荐
在windows iis5下安装php4.0+mysql之我见
Oct 09 PHP
for循环连续求和、九九乘法表代码
Feb 20 PHP
两千行代码的PHP学习笔记汇总
Oct 05 PHP
php缩放gif和png图透明背景变成黑色的解决方法
Oct 14 PHP
PHP中shuffle数组值随便排序函数用法
Nov 21 PHP
php中call_user_func函数使用注意事项
Nov 21 PHP
PHP中iconv函数转码时截断字符问题的解决方法
Jan 21 PHP
php创建session的方法实例详解
Jan 27 PHP
php+curl 发送图片处理代码分享
Jul 09 PHP
PHP批量删除jQuery操作
Jul 23 PHP
php实现姓名根据首字母排序的类与方法(实例代码)
May 16 PHP
laravel 解决强制跳转 https的问题
Oct 22 PHP
PHP+MySQL高并发加锁事务处理问题解决方法
Apr 30 #PHP
PHP使用file_get_contents发送http请求功能简单示例
Apr 29 #PHP
PHP实现通过strace定位故障原因的方法
Apr 29 #PHP
PHP性能测试工具xhprof安装与使用方法详解
Apr 29 #PHP
PHP使用curl_multi实现并发请求的方法示例
Apr 29 #PHP
PHP实现转盘抽奖算法分享
Apr 15 #PHP
PHP cURL获取微信公众号access_token的实例
Apr 28 #PHP
You might like
php设计模式 Chain Of Responsibility (职责链模式)
2011/06/26 PHP
PHP用反撇号执行外部命令
2015/04/14 PHP
PHP连接MYSQL数据库的3种常用方法
2017/02/27 PHP
javascript下给元素添加事件的方法与代码
2007/08/13 Javascript
调用js时ie6和ie7,ff的区别
2009/08/19 Javascript
jQuery实现统计复选框选中数量
2014/11/24 Javascript
js实现将选中内容分享到新浪或腾讯微博
2015/12/16 Javascript
jQuery插件Validate实现自定义校验结果样式
2016/01/18 Javascript
百度地图给map添加右键菜单(判断是否为marker)
2016/03/04 Javascript
实现一个简单的vue无限加载指令方法
2017/01/10 Javascript
基于Node的React图片上传组件实现实例代码
2017/05/10 Javascript
ES6 javascript的异步操作实例详解
2017/10/30 Javascript
Node.js实现用户评论社区功能(体验前后端开发的乐趣)
2019/05/09 Javascript
vue 兄弟组件的信息传递的方法实例详解
2019/08/30 Javascript
微信小程序实现登录注册功能
2020/12/29 Javascript
Cython 三分钟入门教程
2009/09/17 Python
Python回调函数用法实例详解
2015/07/02 Python
详解Python 序列化Serialize 和 反序列化Deserialize
2017/08/20 Python
对Python3中的input函数详解
2018/04/22 Python
在Windows中设置Python环境变量的实例讲解
2018/04/28 Python
Python requests发送post请求的一些疑点
2018/05/20 Python
pandas 使用均值填充缺失值列的小技巧分享
2019/07/04 Python
pytorch多进程加速及代码优化方法
2019/08/19 Python
在python中做正态性检验示例
2019/12/09 Python
python实现全排列代码(回溯、深度优先搜索)
2020/02/26 Python
aws 通过boto3 python脚本打pach的实现方法
2020/05/10 Python
python 实现两个npy档案合并
2020/07/01 Python
使用HTML5拍照示例代码
2013/08/06 HTML / CSS
华为python面试题
2016/05/03 面试题
财务总经理岗位职责
2014/02/16 职场文书
大学生自我鉴定书
2014/03/24 职场文书
2014年学雷锋活动总结
2014/06/26 职场文书
推广活动策划方案
2014/08/23 职场文书
事业单位年度考核评语
2014/12/31 职场文书
PHP中->和=>的意思
2021/03/31 PHP
Netty分布式客户端接入流程初始化源码分析
2022/03/25 Java/Android