141. Linked List Cycle

  1. 问题

    Given a linked list, determine if it has a cycle in it.

    Follow up:
    Can you solve it without using extra space?

  2. 问题描述

    题目很简单就是给一个链表需要判断链表是否有环

  3. 代码

        ListNode p=head;//快指针
        ListNode q=head;//慢指针
        while(p!=null && q!=null && p.next!=null){//边界条件是出现空指针,就返回false;
            q=q.next;
            p=p.next.next;//空指针没有next,否则会出现NullPointerException问题
            if(p==q) return true;
        }
        return false;

这里写图片描述

第一个程序,两个指针一个快一个慢同时进行跑,如果存在环那么whlie是一个死循环一直执行到两个指针指到相同节点

        ListNode firstHead = head;
        while (firstHead != null){
            head = firstHead.next;
            while (head != null){
                if (head == firstHead){
                    return true;
                }else {
                    head = head.next;
                }
            }
            firstHead = firstHead.next;
        }
        return false;

这个程序是一开始想到的,需要的时间复杂度比较高,不能满足,但是程序应该是没有问题的,就是以一个点为起始点,寻找下面的节点在遍历的过程中是否能找到这个起始点,相当于寻找上面图中的第二个节点

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值