脚本宝典收集整理的这篇文章主要介绍了PHP实现的基于单向链表解决约瑟夫环问题示例,脚本宝典觉得挺不错的,现在分享给大家,也给大家做个参考。
本文实例讲述了PHP实现的基于单向链表解决约瑟夫环问题。分享给大家供大家参考,具体如下:
更多的类似问题是:n个人围成圈,依次编号为1,2,..,n,现在从1号开始依次报数,当报到m时,报m的人退出,下一个人重新从1报起,循环下去,问最后剩下那个人的编号是多少?
PHP;"> value = $value; } function addNode($node,$value){ $lastNode = findLastNode($node); $nextNode = new Node(); $nextNode->value = $value; $lastNode->nextNode = $nextNode; } /* 找到最后的节点 */ function findLastNode($node){ if(empty($node->nextNode)){ return $node; }else{ return findLastNode($node->nextNode); } } /* 删除节点 必须head为引用传值 */ function deleteNode(&$head,$node,$m,$k = 1){ if($k + 1 == $m){ if($node->nextNode == $head){ $node->nextNode = $node->nextNode->nextNode; $head = $node->nextNode; return $node->nextNode; }else{ $node->nextNode = $node->nextNode->nextNode; return $node->nextNode; } }else{ return deleteNode($head,$node->nextNode,++$k); } } /* 节点数 */ function countNode($head,$count = 1){ if($node->nextNode == $head){ return $count; }else{ return countNode($head,++$count); } } function PRintNode($head,$node){ echo $node->value . ' '; if($node->nextNode == $head) return; printNode($head,$node->nextNode); } function show($data){ echo ''; print_r($data); echo ''; } $head = new Node(); create($head,1); addNode($head,2); addNode($head,3); addNode($head,4); addNode($head,5); addNode($head,6); addNode($head,7); addNode($head,8); addNode($head,9); addNode($head,10); addNode($head,11); addNode($head,12); $lastNode = findLastNode($head); $lastNode->nextNode = $head; $count = countNode($head,$head); $tmpHead = $head; while ($count > 2) { $tmpHead = deleteNode($head,$tmpHead,3,1); $count = countNode($head,$head); } printNode($head,$head);
以上是脚本宝典为你收集整理的PHP实现的基于单向链表解决约瑟夫环问题示例全部内容,希望文章能够帮你解决PHP实现的基于单向链表解决约瑟夫环问题示例所遇到的问题。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。