php实现猴子选大王问题算法实例


Posted in PHP onApril 20, 2015

本文实例讲述了php实现猴子选大王问题算法。分享给大家供大家参考。具体分析如下:

一、问题:

n只猴子围坐成一个圈,按顺时针方向从1到n编号。
然后从1号猴子开始沿顺时针方向从1开始报数,报到m的猴子出局,再从刚出局猴子的下一个位置重新开始报数,
如此重复,直至剩下一个猴子,它就是大王。

设计并编写程序,实现如下功能:
(1)   要求由用户输入开始时的猴子数$n、报数的最后一个数$m。
(2)   给出当选猴王的初始编号。

二、解决方法:

/**
 * @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));

补充改进算法(该算法更加简洁明了!):

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 相关文章推荐
一篇不错的PHP基础学习笔记
Mar 18 PHP
php zlib压缩和解压缩swf文件的代码
Dec 30 PHP
JS与PHP向函数传递可变参数的区别实例代码
May 18 PHP
php简单获取文件扩展名的方法
Mar 24 PHP
php筛选不存在的图片资源
Apr 28 PHP
php类的定义与继承用法实例
Jul 07 PHP
php安装扩展mysqli的实现步骤及报错解决办法
Sep 23 PHP
Yii框架实现对数据库的CURD操作示例
Sep 03 PHP
PHP实现的微信APP支付功能示例【基于TP5框架】
Sep 16 PHP
Laravel 数据库加密及数据库表前缀配置方法
Oct 10 PHP
laravel 根据不同组织加载不同视图的实现
Oct 14 PHP
PHP7原生MySQL数据库操作实现代码
Jul 03 PHP
php递归删除指定文件夹的方法小结
Apr 20 #PHP
php动态生成缩略图并输出显示的方法
Apr 20 #PHP
PHP随机生成唯一HASH值自定义函数
Apr 20 #PHP
php隐藏实际地址的文件下载方法
Apr 18 #PHP
php实现用于计算执行时间的类实例
Apr 18 #PHP
php递归遍历多维数组的方法
Apr 18 #PHP
php实现二进制和文本相互转换的方法
Apr 18 #PHP
You might like
Javascript与PHP验证用户输入URL地址是否正确
2014/10/09 PHP
PHP中使用jQuery+Ajax实现分页查询多功能操作(示例讲解)
2017/09/17 PHP
PHP Class SoapClient not found解决方法
2018/01/20 PHP
laravel框架关于搜索功能的实现
2018/03/15 PHP
在PHP中输出JS语句以及乱码问题的解决方案
2019/02/13 PHP
javascript 事件查询综合 推荐收藏
2010/03/10 Javascript
js 代码优化点滴记录
2012/02/19 Javascript
nodejs npm包管理的配置方法及常用命令介绍
2014/06/05 NodeJs
深入探讨Vue.js组件和组件通信
2016/09/12 Javascript
jQuery基于排序功能实现上移、下移的方法
2016/11/26 Javascript
JS 中document.write()的用法和清空的原因浅析
2017/12/04 Javascript
vue定义全局变量和全局方法的方法示例
2018/08/01 Javascript
p5.js实现简单货车运动动画
2019/10/23 Javascript
layui点击按钮页面会自动刷新的解决方案
2019/10/25 Javascript
vue中的过滤器及其时间格式化问题
2020/04/09 Javascript
微信小程序实现modal弹出框遮罩层组件(可带文本框)
2020/12/20 Javascript
全面解析Vue中的$nextTick
2020/12/24 Vue.js
python类装饰器用法实例
2015/06/04 Python
python实现linux下使用xcopy的方法
2015/06/28 Python
python+pandas分析nginx日志的实例
2018/04/28 Python
Python读取mat文件,并转为csv文件的实例
2018/07/04 Python
python语音识别实践之百度语音API
2018/08/30 Python
Python通过for循环理解迭代器和生成器实例详解
2019/02/16 Python
Python爬虫 bilibili视频弹幕提取过程详解
2019/07/31 Python
浅谈tensorflow中dataset.shuffle和dataset.batch dataset.repeat注意点
2020/06/08 Python
Python+logging输出到屏幕将log日志写入文件
2020/11/11 Python
canvas与html5实现视频截图功能示例
2016/12/15 HTML / CSS
美国Rue La La闪购网站:奢侈品、中高档品牌限时折扣
2016/10/19 全球购物
英国儿童设计师服装的领先零售商:Base
2019/03/17 全球购物
公司捐款倡议书
2014/05/14 职场文书
幼儿园课题实施方案
2014/05/14 职场文书
营销经理工作检讨书
2014/11/03 职场文书
独生子女证明范本
2015/06/19 职场文书
Python中tkinter的用户登录管理的实现
2021/04/22 Python
react中的DOM操作实现
2021/06/30 Javascript
Python爬虫入门案例之爬取去哪儿旅游景点攻略以及可视化分析
2021/10/16 Python