链表是否有环路问题

查找链表中是否有环路(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的。如果说出现了其中的一个指针位置等于另一指针的下一个位置,就是有环路,直接退出,结束。

转载于:https://www.cnblogs.com/qinyongzhu/p/4960411.html

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值