当前位置:Gxlcms > PHP教程 > PHP实现找出链表中环的入口节点

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

时间:2021-07-01 10:21:17 帮助过:35人阅读

本篇讲解PHP实现找出链表中环的入口节点。

一个链表中包含环,请找出该链表的环的入口结点。

解决思路

第一步,找环中相汇点。分别用p1,p2指向链表头部,p1每次走一步,p2每次走二步,直到p1==p2找到在环中的相汇点。

第二步,找环的入口。接上步,当p1==p2时,p2所经过节点数为2x,p1所经过节点数为x,设环中有n个节点,p2比p1多走一圈有2x=n+x; n=x;可以看出p1实际走了一个环的步数,再让p2指向链表头部,p1位置不变,p1,p2每次走一步直到p1==p2; 此时p1指向环的入口。(还没怎么懂)

实现代码

/*class ListNode{ 
var $val;
var $next = NULL; 
function __construct($x){
$this->val = $x; 
} 
}*/ 
function EntryNodeOfLoop($pHead) 
{ 
if($pHead == null || $pHead->next == null) 
return null; 
$p1 = $pHead; 
$p2 = $pHead; 
while($p2!=null && $p2->next!=null){ 
$p1 = $p1->next;
$p2 = $p2->next->next;
if($p1 == $p2){ 
$p2 = $pHead;
while($p1!=$p2)
$p1 = $p1->next;
$p2 = $p2->next; 
} 
if($p1 == $p2) 
return $p1; 
} 
} 
return null; 
}

本篇讲解PHP实现找出链表中环的入口节点,更多相关内容请关注Gxl网。

相关推荐:

php nginx 实时输出的实现方法

PHP Class SoapClient not found处理方法

php如何实现的mongoDB单例模式操作类

以上就是PHP实现找出链表中环的入口节点的详细内容,更多请关注Gxl网其它相关文章!

人气教程排行