0
点赞
收藏
分享

微信扫一扫

【链表】面试题 02.07. 链表相交

伊人幽梦 2022-03-12 阅读 96

题目:

给你两个单链表的头节点 headA 和 headB ,请你找出并返回两个单链表相交的起始节点。如果两个链表没有交点,返回 null 。

图示两个链表在节点 c1 开始相交:

题目数据 保证 整个链式结构中不存在环。

注意,函数返回结果后,链表必须 保持其原始结构 。

示例 1:

示例 2:

示例 3:

题解:

实际上是找两个链表交点节点的指针。

原理:相交之后的节点都相同,个数也一样,因此将末尾进行对齐。

步骤:

(1)curA指向链表A的头结点,curB指向链表B的头结点;

(2)求出两个链表的长度,并求出两个链表长度的差值,然后让curA移动到,和curB 末尾对齐的位置;

(3)比较curA和curB是否相同,如果不相同,同时向后移动curA和curB,如果遇到curA == curB,则找到交点。

/**
* Definition for singly-linked list.
* public class ListNode {
* int val;
* ListNode next;
* ListNode(int x) {
* val = x;
* next = null;
* }
* }
*/

public class Solution {
public ListNode getIntersectionNode(ListNode headA, ListNode headB) {
ListNode curA = headA;
ListNode curB = headB;
int lengthA = 0;
int lengthB = 0;
while (curA != null) { // 求链表A的长度
lengthA++;
curA = curA.next; // 别忘了往后走
}
while (curB != null) { // 求链表B的长度
lengthB++;
curB = curB.next;
}
curA = headA; //curA、curB都到末尾了,要指向头
curB = headB;
if (lengthA > lengthB) {
int n = lengthA - lengthB;
while (n-- > 0) {
curA = curA.next;
}
} else {
int n = lengthB - lengthA;
while (n-- > 0) {
curB = curB.next;
}
}
while (curA != curB) {
if (curA == null) { // 先比较完再变化指针
return null;
}
curA = curA.next;
curB = curB.next;
}
return curA;
}
}

参考:代码随想录

举报

相关推荐

0 条评论