当前位置: 首页 > 编程笔记 >

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

贝研
2023-03-14
本文向大家介绍php约瑟夫问题解决关于处死犯人的算法,包括了php约瑟夫问题解决关于处死犯人的算法的使用技巧和注意事项,需要的朋友参考一下

本文实例讲述了php约瑟夫问题解决关于处死犯人的算法。分享给大家供大家参考。具体分析如下:

古代某法官要判决IV个犯人的死刑,他有一条荒唐的法律将犯人站成一个圆圈,从第s个人开始数起,每到第D个人就拉出来处死,然后再数D个,再拉出来处决…… 直到剩下最后一个可以赦免.

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);

希望本文所述对大家的php程序设计有所帮助。

 类似资料:
  • 本文向大家介绍PHP实现的基于单向链表解决约瑟夫环问题示例,包括了PHP实现的基于单向链表解决约瑟夫环问题示例的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了PHP实现的基于单向链表解决约瑟夫环问题。分享给大家供大家参考,具体如下: 约瑟夫环问题:在罗马人占领乔塔帕特后,39 个犹太人与Josephus及他的朋友躲到一个洞中,39个犹太人决定宁愿死也不要被敌人抓到,于是决定了一个自杀方式,

  • 一、题目 0, 1, … , n-1 这n个数字排成一个圈圈,从数字0开始每次从圆圏里删除第m个数字。求出这个圈圈里剩下的最后一个数字。 二、解题思路 创建一个总共有n 个结点的环形链表,然后每次在这个链表中删除第m 个结点。 三、解题代码 public static int lastRemaining(int n, int m) { if (n < 1 || m < 1) {

  • 本文向大家介绍php实现约瑟夫问题的方法小结,包括了php实现约瑟夫问题的方法小结的使用技巧和注意事项,需要的朋友参考一下 本文实例总结了php实现约瑟夫问题的方法。分享给大家供大家参考。具体分析如下: 一群猴子排成一圈,按1,2,...,n依次编号。然后从第1只开始数,数到第m只,把它踢出圈,从它后面再开始数, 再数到第m只,在把它踢出去...,如此不停的进行下去, 直到最后只剩下一只猴子为止,

  • 本文向大家介绍约瑟夫问题的Python和C++求解方法,包括了约瑟夫问题的Python和C++求解方法的使用技巧和注意事项,需要的朋友参考一下 么是约瑟夫问题? 约瑟夫问题是一个有趣的数学游戏,游戏规则如下: 1、N个人围成一个圈,编号从1开始,依次到N。 2、编号为M的游戏参与者开始报数,报数从1开始,后面的人报数接龙,直到K为止,报数为K的人将出局。 3、出局者的下一个玩家接着从1开始报数,如

  • 习题2-8 约瑟夫环 约瑟夫(Joseph)问题的一种描述是:编号为1,2,…,n的n个人按顺时针方向围坐一圈,每人持有一个密码(正整数)。一开始以6作为报数上限值m,从第一个人开始按顺时针方向自1开始顺序报数,报到m时停止报数。报m的人出列,将他的密码作为新的m值,再从他在顺时针方向上的下一个人开始重新从1报数,如此下去,直至所有人全部出列为止。请编程输出出列顺序。 输入格式: 首先输入一个整数

  • 本文向大家介绍PHP基于递归实现的约瑟夫环算法示例,包括了PHP基于递归实现的约瑟夫环算法示例的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了PHP基于递归实现的约瑟夫环算法。分享给大家供大家参考,具体如下: 约瑟夫环问题: 39 个犹太人与Josephus及他的朋友躲到一个洞中,39个犹太人决定宁愿死也不要被敌人抓。于是决定了自杀方式,41个人排成一个圆圈,由第1个人开始报数,每报数到第