链表中环的入口结点

链表中环的入口结点

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-03 12:45
西南大学 Java
nsnzkv:你这项目写的内容太多了,说实话都是在给自己挖坑,就算简历过了,后面面试也难受
点赞 评论 收藏
分享
qq乃乃好喝到咩噗茶:院校后面加上211标签,放大加粗,招呼语也写上211
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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