题解 | #链表中环的入口结点#

链表中环的入口结点

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;
    }

但是题目要求空间复杂度有限,就只能参考二指针的单双步方法了。

全部评论

相关推荐

10-27 17:26
东北大学 Java
点赞 评论 收藏
分享
11-06 10:58
已编辑
门头沟学院 嵌入式工程师
双非25想找富婆不想打工:哦,这该死的伦敦腔,我敢打赌,你简直是个天才,如果我有offer的话,我一定用offer狠狠的打在你的脸上
点赞 评论 收藏
分享
评论
点赞
收藏
分享
牛客网
牛客企业服务