当前位置:首页 > PHP教程 > php高级应用 > 列表

php基于环形链表解决约瑟夫环问题示例

发布:smiling 来源: PHP粉丝网  添加日期:2021-08-18 11:42:42 浏览: 评论:0 

这篇文章主要介绍了php基于环形链表解决约瑟夫环问题,结合具体实例形式分析了php环形链表的定义及基于环形链表解决约瑟夫环的具体步骤与相关操作技巧,需要的朋友可以参考下。

本文实例讲述了php基于环形链表解决约瑟夫环问题,分享给大家供大家参考,具体如下:

先来重温一下约瑟夫环问题:N个人围成一圈,从第一个开始报数,第M个将被杀掉,最后剩下一个,其余人都将被杀掉。例如N=6,M=5,被杀掉的顺序是:5,4,6,2,3,1。

前面介绍了关联数组解决约瑟夫环的方法,环形链表解决约瑟夫环的方法如下:

  1. <?php 
  2. header("content-type:text/html;charset=utf-8"); 
  3. class Child{ 
  4. public $no
  5. public $next=null; 
  6. public function __construct($no){ 
  7. $this->no=$no
  8.    } 
  9. function addChild($n,&$first){    //$n是人的个数,创建环形链表 
  10.   for($i=0;$i<$n;$i++){ 
  11.     $child=new Child($i+1); 
  12.     if($i==0){ 
  13.     $first=$child
  14.     $cur=$child
  15.     $cur->next=$cur
  16.     }else
  17.     $cur->next=$child
  18.     $child->next=$first
  19.     $cur=$cur->next; 
  20.          } 
  21.    } 
  22. function showHero($first){ 
  23. $cur=$first
  24. while($cur->next!=$first){ 
  25. echo "<br/>人的编号:".$cur->no; 
  26. $cur=$cur->next; 
  27.      } 
  28.      echo "<br/>人的编号:".$cur->no; 
  29. function countChild($first,$m,$k){ 
  30.   $cur=$first
  31.   for($i=0;$i<$m-1;$i++){ 
  32.   $cur=$cur->next; 
  33.   } 
  34.   $j=0; 
  35.   while($cur!=$cur->next){ 
  36.     if($j==$k-2){ 
  37.       echo "<br/>出列编号:".$cur->next->no; 
  38.       $cur->next=$cur->next->next; 
  39.       $cur=$cur->next; 
  40.       $j=0; 
  41.     }else
  42.       $cur=$cur->next; 
  43.       $j++; 
  44.     } 
  45.   } 
  46.   echo "<br/>最后出列编号:".$cur->no; 
  47. addChild(10,$first); 
  48. showHero($first); 
  49. echo "<hr/>"
  50. countChild($first,2,3); //第二个人开始数,数到三出列 
  51. ?> 

运行结果:

  1. 人的编号:1 
  2. 人的编号:2 
  3. 人的编号:3 
  4. 人的编号:4 
  5. 人的编号:5 
  6. 人的编号:6 
  7. 人的编号:7 
  8. 人的编号:8 
  9. 人的编号:9 
  10. 人的编号:10 
  11. -------------------------------------------------------------------------------- 
  12.  
  13. 出列编号:4 
  14. 出列编号:7 
  15. 出列编号:10 
  16. 出列编号:3 
  17. 出列编号:8 
  18. 出列编号:2 
  19. 出列编号:9 
  20. 出列编号:6 
  21. 出列编号:1 
  22. 最后出列编号:5

Tags: php环形链表 php约瑟夫环

分享到: