一、已知一个单链表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)。
方法三:如果两个没有环的链表相交,那么在这个相交节点之后的每一个节点都是两个链表所共有的,这样,最后一个