• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

php如何实现找出带环链表的环的入口结点(代码实例)

php 搞代码 4年前 (2022-01-21) 16次浏览 已收录 0个评论

本篇文章给大家带来的内容是关于php如何实现找出带环链表的环的入口结点(代码实例),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。

给一个链表,若其中包含环,请找出该链表的环的入口结点,否则,输出null

1.找链表倒数第k个结点,输入一个链表,输出该链表中倒数第k个结点。第一个指针走(k-1)步,到达第k个节点,两个指针本文来源gaodai#ma#com搞@@代~&码*网/搞gaodaima代码同时往后移动,当第一个结点到达末尾的时候,第二个结点所在位置就是倒数第k个节点了

2.原理有点像上面的,定义两个指针,一个是快指针每次走两步,一个是慢指针每次走一步,当两个相遇的时候,假设环的长度为n个结点,慢指针走x步,快指针走2x步,2x=x+kn ;x=kn; k暂时假定为1圈 ,也就是慢指针slow走了一个环的距离

3.快指针回到头结点,慢指针原位置不动,两个每次都是走一步,当两个再次相遇的时候,就是在环入口;想象把环捋直,和倒数第k个结点很像了

slow fastwhile fast!=null && fast->next!=null    slow=slow->next    fast=fast->next->next    if slow==fast        fast=head        while slow!=fast            slow=slow->next            fast=fast->next        if slow==fast            return slowreturn null
<?phpclass Node{        public $data;        public $next;        public function __construct($data=""){                $this->data=$data;        }   }//构造一个带环的链表$linkList=new Node();$linkList->next=null;$temp=$linkList;$node1=new Node("111");$temp->next=$node1;$temp=$node1;$node2=new Node("222");$temp->next=$node2;$temp=$node2;$node3=new Node("333");$temp->next=$node3;$temp=$node3;$node4=new Node("444");$temp->next=$node4;$node4->next=$node2;//尾结点指向第二个结点function EntryNodeOfLoop($pHead){        $slow=$pHead;        $fast=$pHead;        while($fast!=null && $fast->next!=null){                $slow=$slow->next;//慢指针走一步                $fast=$fast->next->next;//快指针走两步                //快慢指针环内相遇                if($slow==$fast){                        //快指针回到头结点                        $fast=$pHead;                        //同一速度再同时走                        while($slow!=$fast){                                $slow=$slow->next;                                $fast=$fast->next;                        }                           //两个相遇的点一定是环的入口                        if($slow==$fast){                                return $fast;                        }                   }           }   }var_dump($linkList);$result=EntryNodeOfLoop($linkList);var_dump($result);
object(Node)#1 (2) {  ["data"]=>  string(0) ""  ["next"]=>  object(Node)#2 (2) {    ["data"]=>    string(3) "111"    ["next"]=>    object(Node)#3 (2) {      ["data"]=>      string(3) "222"      ["next"]=>      object(Node)#4 (2) {        ["data"]=>        string(3) "333"        ["next"]=>        object(Node)#5 (2) {          ["data"]=>          string(3) "444"          ["next"]=>          *RECURSION*        }      }    }  }}object(Node)#3 (2) {  ["data"]=>  string(3) "222"  ["next"]=>  object(Node)#4 (2) {    ["data"]=>    string(3) "333"    ["next"]=>    object(Node)#5 (2) {      ["data"]=>      string(3) "444"      ["next"]=>      *RECURSION*    }  }}

相关推荐:

PHP实现找出链表中环的入口节点

PHP实现循环链表功能

以上就是php如何实现找出带环链表的环的入口结点(代码实例)的详细内容,更多请关注搞代码gaodaima其它相关文章!


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:php如何实现找出带环链表的环的入口结点(代码实例)

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址