Leetcode 02.07. 链表相交

题源: 面试题 02.07. 链表相交

方法:长度差法

解题思路是先遍历两个链表获取它们的长度,然后让长链表的指针先走两链表的长度差步,接着同时遍历两个链表,查找相交的节点。

解题步骤

  1. 初始化:创建两个指针 curAcurB,分别指向两个链表的头节点 headAheadB
  2. 计算长度
    • 遍历链表A,计算长度 lenA
    • 遍历链表B,计算长度 lenB
  3. 长度调整
    • 如果链表B比链表A长,交换两个链表的头指针和长度,确保 curA 指向较长的链表。
    • 计算两个链表的长度差 gap
  4. 移动长链表的指针:让 curA 先前移 gap 步。
  5. 同步遍历:同时遍历两个链表,比较节点是否相同:
    • 如果找到相同的节点,即为交点,返回该节点。
    • 如果直到链表末尾都没有相同的节点,说明两个链表不相交,返回 NULL

代码分析

这个函数利用链表长度差来减少不必要的比较。通过确保两个链表从距离尾部相同距离的位置同步开始遍历,使得它们能在相交点相遇,如果有的话。

复杂度分析

  • 时间复杂度:O(m+n),其中 m 和 n 是两个链表的长度。在最坏的情况下,我们可能需要遍历两个链表的全部长度。
  • 空间复杂度:O(1),因为没有使用额外的空间,只有几个变量用于追踪长度和指针位置。

示例

例如,有两个链表A和B。链表A的节点是 1 -> 2 -> 3 -> 4 -> 5,链表B的节点是 9 -> 4 -> 5,其中值为4和5的节点是共享的。根据该算法,链表A和B的长度分别是5和3,长度差是2。因此,我们让链表A的指针先移动2步,然后两个指针同时移动,它们会在值为4的节点相遇,该节点就是所求的交点。

Code

/**
 * Definition for singly-linked list.
 * struct ListNode {
 *     int val;
 *     ListNode *next;
 *     ListNode(int x) : val(x), next(NULL) {}
 * };
 */
class Solution {
public:
    ListNode *getIntersectionNode(ListNode *headA, ListNode *headB) {
        ListNode *curA = headA;
        ListNode *curB = headB;
        int lenA = 0, lenB = 0;
        while(curA != NULL){    //求链表A的长度
            curA = curA -> next;
            lenA ++;
        }
        while(curB != NULL){    //求链表B的长度
            curB = curB -> next;
            lenB ++;
        }
        curA = headA;  //让curAB恢复到原来的位置
        curB = headB;

        if(lenB > lenA){        //让链表A是最长的链表
            swap(lenA, lenB);
            swap(curA, curB);
        }
        int gap = lenA - lenB;
        while(gap --) curA = curA -> next;
        while(curA != NULL && curB != NULL){ //遍历AB,找到相交的节点
            if(curA == curB) return curA;
            curA = curA -> next;
            curB = curB -> next;
        }
        return NULL;
    }
};
  • 3
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值