如何判断链表有环?

题目描述:

如果有一个单向链表,链表当中有可能出现"环",就像下图这样,如何判断这个链表是有环链表?

方案一:暴力法

从头节点,依次遍历单链表的每一个节点,每到一个新的节点就头节点重新遍历之前的所有的节点,对比此时的节点,如果相同,证明该节点遍历过两次,以此说明链表是有环的

伪代码:

Node p = head.next
while(p.next!==null){
    Node c = head
    while(c!==p){
        c=c.next
    }
    if(c.next!==p.next){
        return true
    }
    p = p.next
}
return false

此方案时间复杂度为O(n^2),空间复杂度为O(1)

第二种方案:用hashMap缓存遍历的过的节点

还是头节点进行遍历,每一次遍历新的节点时,对比存储到hashMap集合是否有相同的节点,有,证明有环,无,存储到集合中

伪代码:

Node p = head
HashMap hm = new HashMap()<Node,Node>
while(p!=null){
    if(hm.get(p)){
        return true
    }
    hm.put(p,p)
    p =p.next
}

此方案的时间复杂度为O(n),空间复杂度为O(n)

 

第三种方案:双指针遍历

首先创建两个指针1和2,同时指向这个链表的头节点。然后开始一个大循环,在循环体中,让指针1每次向下移动一个节点,让指针2每次向下移动两个节点,然后比较两个指针指向的节点是否相同。如果相同,则判断出链表有环,如果不同,则继续下一次循环

伪代码:

Node p = head
Node q = head.next
while(p!==q){
    if(p.next==null) return false
    p =p.next
    if(q.next==null) return false
    if(q.next.next==null) return false  
    q = q.next.next
}
return true

此方案的时间复杂度为O(n),空间复杂度为O(1)

引申的问题:

问题一:判断两个单向链表是否相交

解决思路:

将最后一个节点的指向某个单向链表的头节点,根据之前的判断是否有环的方法去判断是否有环,有环则为相交,无环则不相交

问题二:找出一个有环链表的入环点

解决思路:

转摘:https://blog.csdn.net/yangruxi/article/details/80333000 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值