≡
  • 网络编程
  • 数据库
  • CMS技巧
  • 软件编程
  • PHP笔记
  • JavaScript
  • MySQL
位置:首页 > 网络编程 > PHP笔记

php 解决约瑟夫问题-关于处死犯人的算法

人气:574 时间:2018-09-21

这篇文章主要为大家详细介绍了php 解决约瑟夫问题-关于处死犯人的算法,具有一定的参考价值,可以用来参考一下。

对php解决约瑟夫问题-关于处死犯人的算法感兴趣的小伙伴,下面一起跟随四海网的小编两巴掌来看看吧!
古代某法官要判决IV个犯人的死刑,他有一条荒唐的法律将犯人站成一个圆圈,从第s个人开始数起,每到第D个人就拉出来处死,然后再数D个,再拉出来处决…… 直到剩下最后一个可以赦免.
 

/**
 * php解决约瑟夫问题-关于处死犯人的算法
 *
 * @param 
 * @arrange 512-笔记网: www.q1010.com
 **/
function getNum($n,$m){
	//用于把所有的数存到数组初始化
	$a = array();
	//遍历,存入数组
	for($i=1;$i<=$n;$i++){
		$a[$i] = $i;
	}
	//指针归0
	reset($a);
	while(count($a)>1){ //如果数组中项大于1,继续循环剔除元素
		//剔除规则
		for($j=1;$j<=$m;$j++){
				//如果没有达到数组的最后项
			if(next($a)){
				if($j==$m){
					//删除m项
							   unset($a[array_search(prev($a),$a)]);
				}
			}else{
				//如果next不存在,那么指针归0
			reset($a);
			if($j==$m){
								unset($a[array_search(end($a),$a)]);
				reset($a);
			}
		}
	   }
	}
	return current($a);
}
echo getNum(5,3);
/***   来自四海网(www.q1010.com)   ***/

 

本文来自:http://www.q1010.com/173/826-0.html

注:关于php 解决约瑟夫问题-关于处死犯人的算法的内容就先介绍到这里,更多相关文章的可以留意四海网的其他信息。

关键词:约瑟夫

您可能感兴趣的文章

上一篇:php 导出CSV文件功能实例
下一篇:php 比较两个数据判断用户提交的表单数据是否存在
热门文章
  • PHP 写入WRITE编码为UTF8的文件示例
  • PHP 中文字符串截取函数示例:支持gb2312,gbk,big
  • PHP 简单留言板的制作示例
  • 解决Fatal error: Call to undefined function mb_convert_encoding() in错误问题
  • PHP语言基础(标记、注释、变量、数组、常量、函数)示例
  • php 生成迅雷链接的简单示例
  • php 获取短网址的实现方法
  • PHP 通用分页类的简单示例
  • PHP 使用文件方式导入导出整个MYSQL数据库的实现方法
  • php 获取MYSQL错误的简单示例
  • 最新文章
    • 解决PHP使用redis实现统计缓存MySQL压力的问题
    • php 简单的上传进度条的简单示例
    • php 给html中引用的js和css路径打上版本号的实现方法
    • php 实现计算年龄精准到年月日的实例
    • php+ajax无刷新分页的简单示例
    • 解决php+ajax无刷新上传图片的问题
    • 解决PHP生成HTML静态页面的问题
    • 解决PHP使用uniqid函数生成唯一ID的问题
    • 解决PHP防刷票的一些问题
    • 微信access_token的获取开发的实现方法

四海网收集整理一些常用的php代码,JS代码,数据库mysql等技术文章。