题解 | #链表中环的入口结点#
链表中环的入口结点
http://www.nowcoder.com/practice/253d2c59ec3e4bc68da16833f79a38e4
如题: 描述 给一个长度为n链表,若其中包含环,请找出该链表的环的入口结点,否则,返回null。
数据范围: n\le10000n≤10000,1<=结点值<=100001<=结点值<=10000 要求:空间复杂度 O(1),时间复杂度 O(n)
简单来说就是找到并返回链表的环入口节点,没有环就返回null。
开始就会想到,set集合方便找重复元素,如果链表节点一步步走有重复节点,肯定就形成了环形。
代码如下:
import java.util.HashSet;
public ListNode EntryNodeOfLoop(ListNode pHead) {
HashSet<ListNode> set = new HashSet<>();
ListNode temp = pHead;
while(temp!=null) {
if(set.add(temp)) {
temp=temp.next;
}else {
return temp;
}
}
return null;
}
但是题目要求空间复杂度有限,就只能参考二指针的单双步方法了。