PHP实现找出链表中环的入口节点的相关知识讲解
内容导读
收集整理的这篇技术教程文章主要介绍了PHP实现找出链表中环的入口节点的相关知识讲解,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1248字,纯文字阅读大概需要2分钟。
内容图文
这篇文章主要介绍了PHP实现找出链表中环的入口节点,涉及php针对环形链表的遍历、查找、计算等相关操作技巧,需要的朋友可以参考下本文实例讲述了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指向环的入口。(还没怎么懂)
实现代码
<?php/*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实现可添加水印与生成缩略图的图片处理工具类_php技巧
PHP实现按之字形顺序打印二叉树的方法讲解
PHP获取二叉树镜像的方法讲解
以上就是PHP实现找出链表中环的入口节点的相关知识讲解的详细内容,更多请关注Gxl网其它相关文章!
内容总结
以上是为您收集整理的PHP实现找出链表中环的入口节点的相关知识讲解全部内容,希望文章能够帮你解决PHP实现找出链表中环的入口节点的相关知识讲解所遇到的程序开发问题。 如果觉得技术教程内容还不错,欢迎将网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。