判断链表是否有环

作者: IT_Matters | 来源:发表于2016-07-05 21:05 被阅读95次

    如何判断一个单链表是否有环?有环的话返回进入环的第一个节点的值,无环的话返回-1。如果链表的长度为N,请做到时间复杂度O(N),额外空间复杂度O(1)。
    给定一个单链表的头结点head(注意另一个参数adjust为加密后的数据调整参数,方便数据设置,与本题求解无关),请返回所求值。

    思路:先利用快慢指针判断是否有环.如果有环,当前指针到环起点的位置和头结点到环起点的距离一样.

    import java.util.*;
    
    /*
    public class ListNode {
        int val;
        ListNode next = null;
    
        ListNode(int val) {
            this.val = val;
        }
    }*/
    public class ChkLoop {
        public int chkLoop(ListNode head, int adjust) {
            // write code here
            if(head==null||head.next==null)return -1;
            ListNode fast=head,slow=head;
            do{
                slow=slow.next;
                fast=fast.next.next;
                
            }while(slow!=fast&&fast.next!=null&&fast.next.next!=null);
            if(slow!=fast)return -1;
            slow=head;
            while(slow!=fast){
                fast=fast.next;
                slow=slow.next;
            }
            return slow.val;
                
        }
    }
    

    相关文章

      网友评论

        本文标题:判断链表是否有环

        本文链接:https://www.haomeiwen.com/subject/yjzhjttx.html