判断链表中是否存在环问题、判断两个链表是否相交问题及其扩展

本文探讨了判断单链表是否存在环的方法,包括如何找到环的长度和连接点。此外,还详细介绍了如何判断两个无环链表是否相交,并提供了三种不同方法,包括使用哈希表、链接链表以及比较尾节点。同时,文章讨论了在链表可能含有环的情况下,判断相交的复杂情况,关键在于首先识别链表中的环。
摘要由CSDN通过智能技术生成

一、已知一个单链表p,如何判断它是否存在环。

定义两个指针fast和slow,均初始化为p,fast一次走2步,slow一次走1步,如果两个指针在q处相遇,那么存在环,相遇的地方一定是slow一圈没有走完,fast走完一圈,在走第二圈的时候。

扩展:如何知道环的长度?如何找出环的连接点在哪里?带环链表的长度是多少?

记录q的位置,继续走直到再碰上q那么之间走过的距离就是环的长度;

slow从p重新开始走,fast从q开始走,每次都是走1步,相遇的地方就是环的连接点;

知道环的长度和slow从p到连接点的长度相加就是链表的长度;


二、已知两个没有环的链表p和q,如何判断两个链表是否相交。

方法一:将第一个链表中的节点根据其地址进行hash,建立hash表,然后对第二个链表每个节点地址查询hash表,如果某个节点在hash表中出现,那么说明第二个链表和第一个链表有公共节点。该方法时间复杂度为o(length1+length2);但是它需要o(length1)的存储空间来存储哈希表。

方法二:将第二个链表的头节点链接到第一个链表的最后,遍历第二个链表,如果在此过程中又回到起始点即q,那么说明这两个链表相交。最后注意要恢复原来的状态。去掉第一个链表到第二个链表头节点的链接。时间复杂度为o(length1+length2)。

方法三:如果两个没有环的链表相交,那么在这个相交节点之后的每一个节点都是两个链表所共有的,这样,最后一个

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值