如何判断两个有环单链表是否相交?相交的话返回true,不想交的话返回false。如果两个链表长度分别为N和M,请做到时间复杂度O(N+M),额外空间复杂度O(1)。
给定两个链表的头结点head1和head2(注意,另外两个参数adjust0和adjust1用于调整数据,与本题求解无关)。请返回一个bool值代表它们是否相交。
思路
两个有环链表如果相交,只存在图示三种情况.
所以首先我们都要找到两个链表的入环节点entry1和entry2.如果entry1==entry2,则属于情况(1)或者(2),直接返回true即可.
否则从entry1或者entry2开始遍历,绕环一圈,如果中途发现有等于另一个entry的点,则说明属于(3). 否则就是不相交的两个有环链表.
import java.util.*;
/*
public class ListNode {
int val;
ListNode next = null;
ListNode(int val) {
this.val = val;
}
}*/
public class ChkIntersection {
public boolean chkInter(ListNode head1, ListNode head2, int adjust0, int adjust1) {
ListNode entry1=findCycleEntry(head1);
ListNode entry2=findCycleEntry(head2);
if(entry1==entry2){
return true;
}
else{
ListNode backup=entry1;
do{
entry1=entry1.next;
}while(entry1!=entry2&&entry1!=backup);
return !(entry1==backup);
}
}
//找到入环节点
private ListNode findCycleEntry(ListNode head){
if(head==null||head.next==null)return null;
ListNode fast=head,slow=head;
do{
slow=slow.next;
fast=fast.next.next;
}while(slow!=fast&&fast.next!=null&&fast.next.next!=null);
if(slow!=fast)return null;
slow=head;
while(slow!=fast){
fast=fast.next;
slow=slow.next;
}
return slow;
}
}