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 相关文章推荐
实用函数9
Nov 08 PHP
解析csv数据导入mysql的方法
Jul 01 PHP
thinkphp实现面包屑导航(当前位置)例子分享
May 10 PHP
PHP使用in_array函数检查数组中是否存在某个值
Mar 25 PHP
用PHP代码在网页上生成图片
Jul 01 PHP
php通过前序遍历树实现无需递归的无限极分类
Jul 10 PHP
WordPress中制作导航菜单的PHP核心方法讲解
Dec 11 PHP
PHP创建/删除/复制文件夹、文件
May 03 PHP
Smarty模板常见的简单应用分析
Nov 15 PHP
php 中的closure用法详解
Jun 12 PHP
PHP中strtr与str_replace函数运行性能简单测试示例
Jun 22 PHP
php输出控制函数和输出函数生成静态页面
Jun 27 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分页显示制作详细讲解
2008/11/19 PHP
php跨站攻击实例分析
2014/10/28 PHP
PHP函数实现从一个文本字符串中提取关键字的方法
2015/07/01 PHP
JavaScript 封装Ajax传递的数据代码
2009/06/05 Javascript
jQuery下通过replace字符串替换实现大小图片切换
2012/05/22 Javascript
eclipse如何忽略js文件报错(附图)
2013/10/30 Javascript
javascript常见用法总结
2014/05/22 Javascript
jQuery之Deferred对象详解
2014/09/04 Javascript
Javascript表单验证要注意的事项
2014/09/29 Javascript
JQuery给网页更换皮肤的方法
2015/05/30 Javascript
纯javascript实现四方向文本无缝滚动效果
2015/06/16 Javascript
jQuery实现自定义checkbox和radio样式
2015/07/13 Javascript
Angularjs中使用Filters详解
2016/03/11 Javascript
微信小程序 图片等比例缩放(图片自适应屏幕)
2016/11/16 Javascript
微信小程序 122100版本更新问题解决方案
2016/12/22 Javascript
给Easyui-Datebox设置隐藏或者不可用的解决方法
2017/05/26 Javascript
Vue keep-alive实践总结(推荐)
2017/08/31 Javascript
解决vue热替换失效的根本原因
2018/09/19 Javascript
Vue商品控件与购物车联动效果的实例代码
2019/07/21 Javascript
layui表单验证select下拉框实现验证的方法
2019/09/05 Javascript
如何使用three.js 制作一个三维的推箱子游戏
2020/07/29 Javascript
pycharm 使用心得(五)断点调试
2014/06/06 Python
Python的内存泄漏及gc模块的使用分析
2014/07/16 Python
python检测主机的连通性并记录到文件的实例
2018/06/21 Python
Django集成搜索引擎Elasticserach的方法示例
2019/06/04 Python
Python利用matplotlib绘制约数个数统计图示例
2019/11/26 Python
Python 中如何写注释
2020/08/28 Python
python3代码中实现加法重载的实例
2020/12/03 Python
ET Mall东森购物网:东森严选
2017/03/06 全球购物
介绍一下write命令
2014/08/10 面试题
关于诚信的活动方案
2014/08/18 职场文书
文言文辞职信
2015/02/28 职场文书
走进科学观后感
2015/06/18 职场文书
基于Golang 高并发问题的解决方案
2021/05/08 Golang
MySQL 主从复制数据不一致的解决方法
2022/03/18 MySQL
关于MySQL中explain工具的使用
2023/05/08 MySQL