本文已参与「新人创作礼」活动,一起开启掘金创作之路
给你两个单链表的头节点 headA 和 headB ,请你找出并返回两个单链表相交的起始节点。如果两个链表没有交点,返回 null 。
图示两个链表在节点 c1 开始相交:
题目数据 保证 整个链式结构中不存在环。
注意,函数返回结果后,链表必须 保持其原始结构 。
示例 1:
示例 2:
示例 3:
这题两个做法。1 暴力破解,两层循环搞定
public ListNode getIntersectionNode(ListNode headA, ListNode headB) {
//获取头结点的起始结点
ListNode curA = headA;
ListNode curB = headB;
//两层循环遍历
while (curA != null) {
while (curB != null) {
//地址相等则为同一个结点,即相交
if (curA == curB) {
return curA;
}
curB = curB.next;
}
curA = curA.next;
curB = headB;
}
return null;
}
2 右对齐法。 先把两个链表的长度求出来 比如A链表长度为10 B链表长度为4 因为如果相交了,则在交点之后,可以看做是一个链表了,因为汇合了嘛 所以A的前5位直接不用考虑,不然如果第三位相交,A后面还有7个,B开挂也最多4个。 所以A不妨先右移6位 此时AB右对齐。 再每位比较。
public ListNode getIntersectionNode(ListNode headA, ListNode headB) {
//获取头结点的起始结点
ListNode curA = headA;
ListNode curB = headB;
int lenA = 0;
int lenB = 0;
//A的长度
while (curA != null) {
lenA++;
curA = curA.next;
}
//B的长度
while (curB != null) {
lenB++;
curB = curB.next;
}
curA = headA;
curB = headB;
//让curA为最长链表的头,lenA为其长度
if (lenB > lenA) {
int temLen = lenA;
lenA = lenB;
lenB = temLen;
ListNode tempNode = curA;
curA = curB;
curB = tempNode;
}
//求长度差
int gap = lenA - lenB;
//让curA和curB在同一起点,末尾位置对齐,因为如果是同一结点,后面肯定是相同的。
while (gap > 0) {
curA = curA.next;
gap--;
}
//此时,curA和curB右对齐
while (curA != null) {
if (curA == curB) {
return curA;
}
curA = curA.next;
curB = curB.next;
}
return null;
}