码迷,mamicode.com
首页 > 其他好文 > 详细

链表是否有环路问题

时间:2015-11-12 23:26:49      阅读:210      评论:0      收藏:0      [点我收藏+]

标签:

查找链表中是否有环路(cycle)(注:cycle,有周期的意思,所以注意这里指的是环路的意思)

public static boolean fun(linklist head)

{

boolean check=false;
        ListNode p=head;
        ListNode q=head;
        if(p!=null) {
            if (head.next != null) {
                q = head.next;
                while (true) {
                    if (p == q) {
                        check = true;
                        break;
                    } else if (q == null) {
                        break;
                    } else {
                        p = p.next;
                        if (q.next != null && q.next.next != null)
                            q = q.next.next;
                        else {
                            break;
                        }
                    }
                }
            }
        }
        return check;

}

整个的思想就是每次两个指针,第一个每次移动一个位置。第二个每次移动两个位置。如果或环路的话,最终总有一个时刻会相遇的(以为一个指针会移动了两次,一个移动一次,那么的话,相对移动了一个位置,就是每次会靠近移动慢的指针一个单位。最终的结果就是赶上了最前面的)

以下提供一种方法非常好像的东西,就是一个指针每次移动一个单位,另一个每次都遍历整个链表,如果有一个位置上出现了null 直接得出是无cycle的。如果说出现了其中的一个指针位置等于另一指针的下一个位置,就是有环路,直接退出,结束。

链表是否有环路问题

标签:

原文地址:http://www.cnblogs.com/qinyongzhu/p/4960411.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!