思路:
双指针
我们使用两个指针 node1,node2 分别指向两个链表 headA,headB 的头结点,然后同时分别逐结点遍历,当 node1 到达链表 headA 的末尾时,重新定位到链表 headB 的头结点;当 node2 到达链表 headB 的末尾时,重新定位到链表 headA 的头结点。
这样,当它们相遇时,所指向的结点就是第一个公共结点。









public class Solution {
public ListNode getIntersectionNode(ListNode headA, ListNode headB) {
if(headA==null||headB==null) return null;
ListNode l1=headA,l2=headB;
while(l1!=l2){
l1=l1==null?headB:l1.next;
l2=l2==null?headA:l2.next;
}
return l1;
}
}
本文介绍了一种使用双指针的方法解决链表相交问题,通过两个指针同时遍历两个链表,当它们相遇时找到的第一个节点即为公共节点。这是一种高效的解决方案,适用于链表操作的面试题。
1382

被折叠的 条评论
为什么被折叠?



