题目描述
给一个链表,若其中包含环,请找出该链表的环的入口结点,否则,输出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; } }