链表OJ—相交链表

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档
文章目录

前言

1、相交链表的题目:

方法讲解:

图文解析:

代码实现:

总结


前言

世上有两种耀眼的光芒,一种是正在升起的太阳,一种是正在努力学习编程的你!一个爱学编程的人。各位看官,我衷心的希望这篇博客能对你们有所帮助,同时也希望各位看官能对我的文章给与点评,希望我们能够携手共同促进进步,在编程的道路上越走越远!


提示:以下是本篇文章正文内容,下面案例可供参考

1、相交链表的题目:

方法讲解:

图文解析:

解题思路:

分别找到A、B两个链表的尾节点,尾节点地址相同,就说明两个链表相交;若尾节点地址不同,就说明两个链表不相交。分别求出A、B两个链表的长度,长的先走差距步,然后再同时走,当节点的地址相同时,就说明这个节点就是相交的起始节点。

代码实现:

cs 复制代码
 typedef struct ListNode ListNode;
struct ListNode *getIntersectionNode(struct ListNode *headA, struct ListNode *headB) {
   struct ListNode*cur1 = headA;
   struct ListNode*cur2 = headB;
    int len1 = 1;
    int len2 = 1;
    //求链表A、B的长度
    //链表A、B的最后一个节点的不满足循环条件,就没进去
    while(cur1->next)
    {
        len1++;
        cur1 = cur1->next;
    }
    while(cur2->next)
    {
        len2++;
        cur2 = cur2->next;
    }
    //判断链表A、B是否相交
    if(cur1 != cur2)
    {
        return NULL;
    }
    //求链表A、B长度差的绝对值
    int n = abs(len1 - len2);
    //假设链表A比链表B的长度长
    struct ListNode*longList = headA;
    struct ListNode*shortList = headB;
    if(len2>len1)
    {
        longList = headB;
        shortList = headA;
    }
    //长的先走差距步
    while(n--)
    {
        longList = longList->next;
    }
    //同时走
    while(longList != shortList)
    {
        longList = longList->next;
        shortList = shortList->next;
    }
    return longList;
}

总结

好了,本篇博客到这里就结束了,如果有更好的观点,请及时留言,我会认真观看并学习。
不积硅步,无以至千里;不积小流,无以成江海。

相关推荐
s1hiyu几秒前
C++动态链接库开发
开发语言·c++·算法
(❁´◡`❁)Jimmy(❁´◡`❁)2 分钟前
CF2188 C. Restricted Sorting
c语言·开发语言·算法
We་ct2 分钟前
LeetCode 54. 螺旋矩阵:两种解法吃透顺时针遍历逻辑
前端·算法·leetcode·矩阵·typescript
星火开发设计6 分钟前
C++ 预处理指令:#include、#define 与条件编译
java·开发语言·c++·学习·算法·知识
想放学的刺客16 分钟前
单片机嵌入式试题(第27期)设计可移植、可配置的外设驱动框架的关键要点
c语言·stm32·单片机·嵌入式硬件·物联网
mit6.82430 分钟前
dijk|tire+floyd+dp %
算法
独自破碎E1 小时前
【总和拆分 + 双变量遍历】LCR_012_寻找数组的中心下标
数据结构·算法
WBluuue1 小时前
Codeforces 1076 Div3(ABCDEFG)
c++·算法
BackCatK Chen1 小时前
第 1 篇:软件视角扫盲|TMC2240 软件核心特性 + 学习路径(附工具清单)
c语言·stm32·单片机·学习·电机驱动·保姆级教程·tmc2240
u0109272711 小时前
模板编译期排序算法
开发语言·c++·算法