欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  php教程

环形链表解决约瑟夫问题

程序员文章站 2022-05-15 16:15:38
...
php代码:
//环形链表
    /*
        解决约瑟夫问题
        设定编号1-n个人 约定起始编号k的人从1开始报数,报到m的那个人出列。他的下一位又从1开始报数,数到M的那个人又出列,
        依次类推,直到所有人都出列为止,求出列顺序,和最后出列编号
     
    */
     
 
     
     
header("content-type:text/html;charset=utf-8");
    class Child{
        public $no;
        public $next=null;
      
        public function __construct($no){
        $this->no=$no;
        }
    }
     
    function addChild(&$first,$n)
    {
        $cur=null;
        for($i=0;$i<=$n-1;$i++){
            $child = new child($i+1);
            if($i==0){
                $first = $child;
                $first->next=$child;
                $cur=$first;
            }else{
                $cur->next=$child;
                $child->next=$first;
                $cur=$cur->next;
            }   
             
        }
    }
     
    function showChild($first){
         
        $cur=$first;
         
        while($cur->next != $first){
            echo $cur->no;
            $cur=$cur->next;
        }
        echo $cur->no;
    }
     
     
    function countChild($first,$m,$k)
    {
        $tail=$first;
        //考虑从第几个孩子开始
        for($i=0;$i<$m-1;$i++){
            $tail=$tail->next;
        }
         
        while($tail->next!=$tail) //剔除到链表中只有一个元素为止
        {
            for($i=0;$i<$k-1;$i++){
                $cur=$tail;//记录他的前一个位置
                $tail=$tail->next;
            }
            echo '出列人'.$tail->no;
            $cur->next=$tail->next;
            $tail=$tail->next;
        }
        echo '111'.$tail->no;
    }
     
addChild($first,10);
showChild($first);
echo "<hr/>";
countChild($first,2,3); //第二个小孩开始数,数到三出列