链表中环的入口结点

链表中环的入口结点

http://www.nowcoder.com/questionTerminal/253d2c59ec3e4bc68da16833f79a38e4

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

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

    public ListNode EntryNodeOfLoop(ListNode pHead)
    {
        ArrayList<ListNode> list = new ArrayList<>();
        ListNode node = pHead;
        while(node != null){
            if(list.contains(node)){
                return node;
            }else{
                list.add(node);
                node = node.next;
            }
        }
        return null;
    }
}

另一种不需要空间复杂度为O(1)的

 if(pHead == null || pHead.next == null || pHead.next.next == null){
            return null;
        }
        ListNode slow = pHead.next;
        ListNode fast = pHead.next.next;
        while(fast != slow){
            if(fast.next == null || fast.next.next == null){
                return null;
            }
            fast = fast.next.next;
            slow = slow.next;
        }
        //得到环的长度
        ListNode mid = pHead;
        fast = fast.next;
        while(fast != slow){
            fast = fast.next;
            mid = mid.next;
        }
        mid = mid.next;
        fast = pHead;
        while(fast != mid){
            fast = fast.next;
            mid = mid.next;
        }
        return fast;
全部评论

相关推荐

05-07 17:58
门头沟学院 Java
wuwuwuoow:1.简历字体有些怪怪的,用啥写的? 2.Redis 一主二从为什么能解决双写一致性? 3.乐观锁指的是 SQL 层面的库存判断?比如 stock > 0。个人认为这种不算乐观锁,更像是乐观锁的思想,写 SQL 避免不了悲观锁的 4.奖项证书如果不是 ACM,说实话没什么必要写 5.逻辑过期时间为什么能解决缓存击穿问题?逻辑过期指的是什么 其实也没什么多大要改的。海投吧
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务