[摘要]本篇文章给大家带来的内容是关于php如何实现找出带环链表的环的入口结点(代码实例),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。给一个链表,若其中包含环,请找出该链表的环的入口结点...
本篇文章给大家带来的内容是关于php如何实现找出带环链表的环的入口结点(代码实例),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。
给一个链表,若其中包含环,请找出该链表的环的入口结点,否则,输出null
1.找链表倒数第k个结点,输入一个链表,输出该链表中倒数第k个结点。第一个指针走(k-1)步,到达第k个节点,两个指针同时往后移动,当第一个结点到达末尾的时候,第二个结点所在位置就是倒数第k个节点了
2.原理有点像上面的,定义两个指针,一个是快指针每次走两步,一个是慢指针每次走一步,当两个相遇的时候,假设环的长度为n个结点,慢指针走x步,快指针走2x步,2x=x+kn ;x=kn; k暂时假定为1圈 ,也就是慢指针slow走了一个环的距离
3.快指针回到头结点,慢指针原位置不动,两个每次都是走一步,当两个再次相遇的时候,就是在环入口;想象把环捋直,和倒数第k个结点很像了
slow fast
while 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 slow
return null