约瑟夫环问题的PHP实现 使用PHP数组内部指针操作函数

 更新时间:2010年10月12日 20:34:40   作者:  
约瑟夫环问题相信大家都已经很熟悉了,一直想使用 PHP 来实现一下,琢磨了老半天的时间终于弄出来了,也许没有网上的一些代码实现的简洁高效,但是毕竟是写出来了~呵呵。
来看看这个问题的详细描述:
view sourceprint?一群猴子排成一圈,按 1,2,...,n 依次编号。然后从第 1 只开始数,数到第 m 只,把它踢出圈,从它后面再开始数, 再数到第 m 只,在把它踢出去...,如此不停的进行下去, 直到最后只剩下一只猴子为止,那只猴子就叫做大王。要求编程模拟此过程,输入 m、n, 输出最后那个大王的编号。
刚开始构思的时候想使用 PHP 数组来实现(当然最后还是使用的数组),然后模拟一个数组的内部指针,结果发现想模拟一个“数组指针”不是那么的容易,因为涉及到很多“指针”的操作,最后猛然想到,PHP 的数组本身就是有内部指针的,为什么还要去“造车轮子”呢?!于是乎~看代码:
复制代码 代码如下:

function getKingMonkey($n, $m)
{
$a = array();//声明内部数组
for($i = 1; $i <= $n; $i ++)
{
$a[$i] = $i;//这一步是对号入座
}
reset($a);//为了严谨,我们来一个 reset() 函数,其实也可以省去
while(count($a) > 1)//主循环开始,这里使用的判别条件是数组元素的个数等于 1 的时候停止循环
{
for($counter = 1; $counter <= $m; $counter++)//嵌套的 for 循环,用来“踢出”数到 m 的猴子
{
if(next($a)){//如果存在 next 元素
if($counter == $m)
{
unset($a[array_search(prev($a), $a)]);//当数到 m 时,使用 unset() 删除数组元素
}
}
else//如果不存在 next 元素
{
reset($a);//则数组的第一个元素充当 next 元素
if($counter == $m)
{
unset($a[array_search(end($a), $a)]);//当数到 m 时,使用 unset() 删除数组元素,注意这里是 end()
reset($a);//记得让数组内部指针“归位”
}
}
}
}
return current($a);
}

测试一下下:
echo "猴子大王的编号为:" . getKingMonkey(100, 17);
输出为:
view sourceprint?猴子大王的编号为:53
The End~

相关文章

  • PHP教程之PHP中shell脚本的使用方法分享

    PHP教程之PHP中shell脚本的使用方法分享

    我们都知道,在计算机科学中,SHELL类似于DOS下的command.com。它接收用户命令,然后调用相应的应用程序。同时它又是一种程序设计语言
    2012-02-02
  • 非常好用的两个PHP函数 serialize()和unserialize()

    非常好用的两个PHP函数 serialize()和unserialize()

    使用serialize()函数和unserialize()函数,这两个函数的用法真是绝配,一个是进行序列化存储,另一个则是进行序列化恢复,方便极了
    2012-02-02
  • php桥接模式的实例用法及代码分析

    php桥接模式的实例用法及代码分析

    在本篇内容里小编给大家整理了一篇关于php桥接模式的实例用法及代码分析内容,有需要的朋友们可以学习下。
    2021-07-07
  • php实现的读取CSV文件函数示例

    php实现的读取CSV文件函数示例

    这篇文章主要介绍了php实现的读取CSV文件函数,结合实例形式分析了php读取CSV文件及字符串、数组遍历与转换等操作技巧,需要的朋友可以参考下
    2017-02-02
  • PHP简单实现遍历目录下特定文件的方法小结

    PHP简单实现遍历目录下特定文件的方法小结

    这篇文章主要介绍了PHP简单实现遍历目录下特定文件的方法,结合2个简单实例总结分析了php针对目录下指定文件的遍历查询操作技巧,需要的朋友可以参考下
    2017-05-05
  • php生成excel列名超过26列大于Z时的解决方法

    php生成excel列名超过26列大于Z时的解决方法

    这篇文章主要介绍了php生成excel列名超过26列大于Z时的解决方法,是针对采用PHPExcel生成excel列数过多的情况下的完善技巧,具有一定的参考借鉴价值,需要的朋友可以参考下
    2014-12-12
  • php中使用explode查找某个字符是否存在的方法

    php中使用explode查找某个字符是否存在的方法

    为了使输入方便,减少在装修编辑模块的时候出现太多的文字框,需要用到在一个框内输入两三种不同内容,然后再使用一些特殊字符来分隔开,用explode来建立一组数据的方法。
    2011-07-07
  • php微信支付之APP支付方法

    php微信支付之APP支付方法

    这篇文章主要介绍了php微信支付之APP支付方法,实例分析了php微信支付接口文件及使用技巧,需要的朋友可以参考下
    2015-03-03
  • 小文件php+SQLite存储方案

    小文件php+SQLite存储方案

    在互联网快速发展的背景下,网络上的数据内容呈几何级的增长,而其中增长最快并且最容易给信息基础架构带来挑战的就是数目庞大的小文件(如图片、电子图书、邮件等)。
    2010-09-09
  • php7中停止php-fpm服务的方法详解

    php7中停止php-fpm服务的方法详解

    这篇文章主要给大家介绍了关于php7中如何停止php-fpm服务的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-04-04

最新评论