链表中环的入口结点

Posted yihangzhou

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了链表中环的入口结点相关的知识,希望对你有一定的参考价值。

题目描述

给一个链表,若其中包含环,请找出该链表的环的入口结点,否则,输出null。
 
/*
时间复杂度为O(n),两个指针,一个在前面,另一个紧邻着这个指针,在后面。
两个指针同时向前移动,每移动一次,前面的指针的next指向NULL。
也就是说:访问过的节点都断开,最后到达的那个节点一定是尾节点的下一个,
也就是循环的第一个。
这时候已经是第二次访问循环的第一节点了,第一次访问的时候我们已经让它指向了NULL,
所以到这结束。
*/

/*
 public class ListNode {
    int val;
    ListNode next = null;

    ListNode(int val) {
        this.val = val;
    }
}
*/
public class Solution {

    public ListNode EntryNodeOfLoop(ListNode pHead)
    {
        if(pHead.next == null) return null;
        ListNode pre = pHead;
        ListNode front = pHead.next;
        while(pre.next != null) {
            pre.next = null;
            pre = front;
            front = front.next;
        }
        return pre;
    }
}

 

以上是关于链表中环的入口结点的主要内容,如果未能解决你的问题,请参考以下文章

链表中环的入口结点

链表中环的入口结点

剑指OFFER 链表中环的入口结点

链表中环的入口结点

牛客网高频算法题系列-BM7-链表中环的入口结点

55.链表中环的入口结点