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

链表中环的入口结点

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

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

全部评论

相关推荐

今年读完研的我无房无车无对象,月入还没有过万&nbsp;看到他在朋友圈晒房产证,感叹自己白读了这么多年书
梦想是成为七海千秋:那咋了,双9毕业的现在还没存款呢(因为没念完),高中毕业的去直播带货月入几百万也是完全有可能的,退一万步讲,有些人刚出生父母就给买车买房了,上哪说理去,哪怕是同一个起点也会有截然不同的走向,过好自己的生活就完事了。
点赞 评论 收藏
分享
05-30 12:03
山西大学 C++
offer来了我跪着接:不是骗子,等到测评那一步就知道为啥这么高工资了
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务