【单链表算法实战】解锁数据结构核心谜题——相交链表

题目如下:

解题过程如下:

相交链表只可以在中间任意位置/头/尾结点相交,如下图:

一个next指针只能指向一块地址,所以不会出现这种情况:

在返回相交链表的起始结点之前先要判断两个链表是否相交,分析下列两种方法是否可行?

  1. 遍历两个链表,判断结点(地址)是否相同。如果像示例1一样,两个链表的长度不等,代码运行结果就是两个链表不会相交,这与事实恰恰相反。所以这个方法不可行:

  2. 看两个链表的尾结点(地址)是否相同。参考相交链表的三种情况,尾结点相同那么两个链表就一定相交。

那么怎么返回相交链表的起始结点呢?

思路:求两个链表的长度,长链表先走长度差步,长短链表遍历比较结点的地址是否相同。

完整代码如下:

c 复制代码
/**
 * Definition for singly-linked list.
 * struct ListNode {
 *     int val;
 *     struct ListNode *next;
 * };
 */
typedef struct ListNode ListNode;
struct ListNode *getIntersectionNode(struct ListNode *headA, struct ListNode *headB) {
    //求两个链表的长度
    ListNode* pa = headA;
    ListNode* pb = headB;
    int sizeA = 0;
    int sizeB = 0;
    while (pa)
    {
        ++sizeA;
        pa = pa->next;
    }
    while (pb)
    {
        ++sizeB;
        pb = pb->next;
    }
    //长链表先走长度差(gap)步
    int gap = abs(sizeA - sizeB);
    ListNode* shortList = headA;
    ListNode* longList = headB;//假设B是长链表
    if (sizeA > sizeB)
    {
        shortList = headB;
        longList = headA;
    }
    while (gap--)
    {
        longList = longList->next;
    }
    //长短链表遍历结点的地址是否相同
    while (longList) //等同于shortList != NULL
    {
        if (longList == shortList)
            return longList;
        longList = longList->next;
        shortList = shortList->next;
    }
    return NULL;
}

abs()函数用于求绝对值:

相关推荐
sinat_2869451916 小时前
AI Coding LSP
人工智能·算法·prompt·transformer
星马梦缘16 小时前
算法与数据结构
数据结构·c++·算法·动态规划·克鲁斯卡尔·kahn
故事不长丨16 小时前
Java List集合深度解析:从基础用法到实战技巧
java·链表·list·集合
2501_9434691516 小时前
【无标题】
数据结构·算法
_codemonster16 小时前
计算机视觉入门到实战系列(八)Harris角点检测算法
python·算法·计算机视觉
逑之16 小时前
C语言笔记16:文件操作
c语言·笔记·单片机
Snow_day.16 小时前
有关排列排列组合(1)
数据结构·算法·贪心算法·动态规划·图论
逑之17 小时前
C语言笔记15:动态内存管理
c语言·网络·笔记
zfxwasaboy17 小时前
DRM KMS 子系统(3)CRTC
linux·c语言
dora17 小时前
【开发火星地平线辅助】智商不够,编程来凑
算法