【算法专题--链表】相交链表--高频面试题(图文详解,小白一看就会!!)

news2025/2/26 11:07:46

目录

一、前言

二、题目描述 

三、解题方法

 ⭐双指针 --- 数学思维

 ⭐双指针 --- 按链表长度计算

🥝 判断相交

🍇 求出交点

🍍实现步骤 

四、总结与提炼

五、共勉 


一、前言

        相交链表这道题,可以说是--链表专题--,比较经典的一道题,也是在面试中频率较高的一道题目,通常在面试中,面试官可能会要求我们写出多种解法来实现这道题目,所以大家需要对这道题目非常熟悉哦!!
        本片博客就来详细的讲讲解一下 相交链表 的多种实现方法,让我们的面试变的更加顺利!!!

二、题目描述 

 题目连接:160. 相交链表 - 力扣(LeetCode)

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

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

 示例 1:

 示例 2:

 三、解题方法

 ⭐双指针 --- 数学思维

 解题思路:

  •  通过找规律,我们可以发现,将 两个 链表 -- 连接 --起来,就可以找出 相交的节点

例如:

这两个 链表  值相同 ------- 代表同一节点, 0  ------代表空节点

  • 链表 A:1 -> 2 -> 3 -> 7 -> 8 -> 9 
  • 链表 B:4 -> 5-> 7 -> 8 -> 9 

连接  两个链表 ---- 表 与 表 之间用 0 隔开

  • AB表 :1,2,3,7,8,9,0,4,5,7,8,9,0
  • BA表 :4,5,7,8,9,0,1,2,3,7,8,9,0】 

 观察连接后的两个表,可以发现 相交的部分整齐的排列在末尾 ---- 【7,8,9,  0

 只需要逐个遍历 这两张表的节点找出第一个 值相同 的节点即可


 如果没有相交会出现 什么样的情况呢?

  • 链表 A:1 -> 2 -> 3 
  • 链表 B:4 -> 5

 连接  两个链表 ---- 表 与 表 之间用 0 隔开

  • AB表 :1,2,3,0,4,5,0
  • BA表 :4,5,0,1,2,3,0】 

观察连接后的两个表,可以发现 相交的部分必然 为 ---- 0(NULL)

参照上面的 逻辑 ,返回首个 相同的节点,为空是符合题意(两个链表不相交) 


代码:

         在写代码 的时候,不可能往 链表中注入 空节点 ,所以我们可以通过一个指针,模拟遍历两个链表相交的过程,当指针指向 空的时候,重新指向另一个链表的头节点,否则就指向下一个节点。

class Solution {
public:
    ListNode *getIntersectionNode(ListNode *headA, ListNode *headB) 
    {
        // 定义 两个指针 用来遍历 两个 链接表 :  AB表  BA表
        ListNode* a = headA;
        ListNode* b = headB;

        // 找到第一个 相同的节点返回即可
        while(a!=b)
        {
            // 遍历完 A 再去 遍历 B
            if(a!=nullptr)
            {
                a = a->next;
            }
            else
            {
                a = headB;
            }

            // 遍历完 B 再去 遍历 A
            if(b!=nullptr)
            {
                b = b->next;
            }
            else
            {
                b = headA;
            }
        }

        return a;
    }
};

 ⭐双指针 --- 按链表长度计算

这道题拆分的话,其实就是两步: 

  1. 判断两个链表是否相交
  2. 然后找出第一个交点 

 🥝 判断相交

首先要判断链表 A 和 链表 B 是否相交,那怎么判断呢? 

A链表 找到 尾节点B链表 也找到 尾节点
 
尾节点 的地址相同时,就是 相交
 
这种方法的时间复杂度为:O ( M + N ) 

🍇 求出交点

既然能判断链表是否相交了,那么如何找到交点呢?

也很简单,直接说方法:

1️⃣:求出 A链表 的长度 La,再求出 B链表 的长度 Lb
2️⃣:如果 A链表 比 B链表 长,那么 A链表 先走 La - Lb 步;

3️⃣ :当 A链表 走了 差距步 以后,再让 A链表 和 B链表 再一起走,第一个 地址 相等的就是交点。

注意: 

如果 B链表 比 A链表 长,那么让 B链表 先走 Lb - La 步;
为什么要用 长的 减去 短的?因为这样得到的结果才是一个 正数 呀,这两个相减得到的值就是 差距步

🍍实现步骤 

  • 既然判断相交要从 头节点 开始走到 尾节点,那么我们就重新定义两个指针 tailA 和 tailB 分别指向 链表A 和 链表B 的头节点,然后开始往后走;
  •  tailA 先走,当 tailA 走到 尾节点 时,就停下来(动图演示👇)

 然后 tailB 再走,当 tailB 走到 尾节点 时,就停下来(动图演示👇)

注意:这里是走到 尾节点,也就是说当 尾节点 的 next 指向 NULL 时,就停下来。 

  • 然后再把 tailA 和 tailB 进行比较,如果它们的 地址 相等,说明相交,就找交点;如果 地址 不相等,就返回 NULL
  • 既然 地址 相等,那我们就要找交点,但是得先求出 A链表 和 B链表 的长度;
  • 定义两个整型 lenA 和 lenB,分别用来表示长度,初始值设为 1

 计算 lenA 的过程👇

计算 lenB 的过程👇 

注意: 

为什么把 lenA 和 lenB 的 初始值设为 1 呢?
 
因为要求链表长度,也就是走到 尾节点 就结束了;

也就说从第一个节点开始计算,当走到 尾节点 时,就结束,相当于 尾节点 没有计算,所以就少算了 1 个。

  •  然后就是求出 差距步,让  的链表先走 差距步,然后再一起走;
  • 此时 lenB 大于 lenA,求出 差距步 为 1; 
  • 所以我们重新定义两个指针,longtList 指向 B 的头节点,shortList 指向 A 的头节点,然后让 longList 先走 差距步,也就是先走 1步(动图演示👇) 

此时再让 longList 和 shortList 一起走,走到相等的位置就停下来(动图演示👇) 

注意: 

上面的图中给的链表是 B 长,A 短,但是实际情况有可能是 A 长,B 短;也有可能是 A 和 B 一样长;


所以我们要把长度进行判断,假设默认先设为 A 长,B 短;


如果 lenA 大于 lenB,那么假设成立,就求 差距步


如果 lenA 小于 lenB,那么说明假设不成立,重新定义即可。


代码实现: 

class Solution {
public:
    ListNode *getIntersectionNode(ListNode *headA, ListNode *headB) 
    {
        ListNode* tailA; 
        tailA = headA;
        ListNode* tailB;
        tailB = headB;

        int lenA = 1;  // 存放A链表的长度
        int lenB = 1;  // 存放B链表的长度

        // A 链表找尾节点
        while(tailA->next!=nullptr)
        {
            tailA = tailA->next;
            lenA++;
        }

        // B 链表找尾节点
        while(tailB->next!=nullptr)
        {
            tailB = tailB->next;
            lenB++;
        }

        // 如果 尾地址不相等,就是不相交,返回空
        if(tailA!=tailB)
        {
            return nullptr;
        }

        // 若相交,求交点
        // 链表长的先走 “差距步”,然后一起走
        ListNode* shortList = headA;  // 假设A短
        ListNode* longList = headB;   // 假设B长

        // 如果 A长于B
        if(lenA>lenB)
        {
            // 那么就交换一下
            longList = headA;
            shortList = headB;
        }

        // 求出差距步
        int gap = abs(lenA - lenB);

        // 长的先走差距步
        while(gap--)
        {
            longList = longList->next;
        }

        // 然后同时走
        while(shortList!=nullptr && longList!=nullptr)
        {
            // 相交
            if(shortList == longList)
            {
                return shortList;
            }

            shortList = shortList->next;
            longList = longList->next;
        }

        return nullptr;
    }
};

 四、总结与提炼

        最后我们来总结一下本文所介绍的内容,本文讲解来一道力扣中有关链表相交的题目,这道题目是校招笔试面试中有关链表章节非常高频的一道题目大家下去一定要自己再画画图,分析一下,把这段代码逻辑自己实现一遍,才能更好地掌握 

五、共勉 

       以下就是我对 链表相交 的理解,如果有不懂和发现问题的小伙伴,请在评论区说出来哦,同时我还会继续更新对 链表专题 的理解,请持续关注我哦!!! 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1823625.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

docker-compose部署FastDFS分布式文件系统

文章目录 一、技术选型二、fastDFS组成部分三、docker-compose文件四、客户端nginx配置五、存储器spring Boot集成参考文献 一、技术选型 还有一个更好的google FS(但是他不开源,我也没找到社区版一类的可以不要钱使用的)。 最后考虑到我们存…

通信设备的网卡

一、网卡的作用 将计算机或者路由器连接到传输介质上的接口,传输介质可以是有线也可以是无线的。 (1)计算机的网卡 现在的计算机大多有两个网卡,一个是有线网卡一个无线网卡,比如以我们的台式电脑为例 台式电脑千兆网…

推进现代化的财务计划,打造可持续的企业发展

现阶段一个重大问题是,大多数企业无法保持决策与规划水平的一致性,财务团队的现状难以支持复杂环境下的新型决策,从而造成了劳动力和资源的错误匹配。由于财务功能的过度扩展,企业难以持续发展。财务团队不得不为了企业的存亡不断…

【代码】数据类型之复合数据类型

Hello!大家好,我是学霸小羊,今天讲讲数据类型之复合数据类型。 上一个博客讲了讲基本数据类型,今天讲讲复合数据类型,没学过基本数据类型的建议先去学一学哈。 【代码】数据类型之基本数据类型https://blog.csdn.net…

AI论文速读 | 2024[SIGIR]基于大语言模型的下一个兴趣点推荐

论文标题:Large Language Models for Next Point-of-Interest Recommendation 作者:Peibo Li ; Maarten de Rijke ; Hao Xue (薛昊); Shuang Ao ; Yang Song ; Flora D. Salim 机构:新南威尔士大学(UNSW)&#xff0c…

MAC M1系统编译ffmpeg-gl-transition

MAC M1系统编译ffmpeg-gl-transition 1. 本人系统2. 编译💰系统准备2.1. 下载【ffmpeg-gl-transition】到用户家目录下,并解压2.2 下载ffmpeg源码2.3. brew安装GLEW glfw32.4 复制vf_gltransition.c文件到ffmpeg2.5 修改ffmpeg源码文件2.6 设置库目录和…

这4款国产软件,因为太良心好用,甚至被误认为是外国人开发的

说起国产软件,大家总是容易给它们打上“流氓、要钱、广告满天飞”的标签,其实,有些小众的软件超级好用,功能强大又不耍流氓,真心不该被一棍子打死。 1、sunlight studio Sunlight Studio是一个开源、免费、无广告的硬…

【成品设计】基于物联网的停车管理系统设计与实现

《基于物联网的停车管理系统设计与实现》 整体功能: 本次课题中,主要设计的是一款基于物联网技术的校园停车的管理系统,该系统能更方便得让管理员对停车场进行管理,同时也能够满足和方便用户使用。针对此种现象,就需…

【面试干货】抽象类和接口的区别

【面试干货】抽象类和接口的区别 1、抽象类1.1、什么是抽象类?1.2、示例代码 2、接口2.1、什么是接口?2.2、示例代码 3、比较和总结3.1、使用场景3.2、关键区别3.3、代码示例比较 💖The Begin💖点点关注,收藏不迷路&am…

大规模装箱问题:蜣螂优化算法DBO求解二维装箱问题(MATLAB代码)

一、问题描述 装载率:所有选择的箱子的总面积与夹板面积之比 假设一共有300个箱子,如何设计算法,使得选择部分箱子放入80*80的甲板上,让甲板的装载率越大,要求箱子间不得重叠。 二、蜣螂优化算法求解二维装箱问题 蜣螂优化算法…

八 、VS的调试技巧

--- 24.4.20 目录 1、什么是Bug? 2、什么是调试(Debug)? 3、Debug和Release 4、VS基础调试快捷键 4.1、环境准备 4.2、调试快捷键 5、监视和内存观察 5.1、监视窗口 5.2、内存窗口 6、调试举例1 7、调试举例2 8、调试…

AI宣传文案软件有哪些?5款AI软件推荐

AI宣传文案软件有哪些?AI宣传文案软件在现代营销和创意产业中扮演着越来越重要的角色,它们凭借先进的自然语言处理、机器学习和深度学习技术,不仅解放了创作者的双手,还大大提升了文案的生成效率和质量。这些软件能够精准捕捉用户…

Polarion重启时自动删除.config

Polarion二次开发的插件中,对Servlet新增、修改或删除时,发布到应用需要删除.config文件才能使修改生效,每次需要手动执行,不如加到restart启动脚本中。只需修改start函数即可。 代码如下: vi /opt/polarion/bin/pola…

(科学:某天是星期几)泽勒一致性是由克里斯汀·泽勒开发的用于计算某天是星期几的算法。

(科学:某天是星期几)泽勒一致性是由克里斯汀泽勒开发的用于计算某天是星期几的算法。这个公式是: 其中: h是一个星期中的某一天(0 为星期六;1 为星期天;2 为星期一;3 为星期二;4 为 星期三;5 为星期四;6为星期五)。 q 是某月的第几天。 m 是月份(3 为三月,4 为四月,…

包装类的应用

一.什么是包装类 基本数据类型所对应的引用数据类型 二.集合中不能存储基本数据类型 三.JDK5以后对包装类新增了什么特性? // 自动装箱:把基本数据类型会自动的变成对应的包装类 // 自动拆箱:把包装类自动的变成其对象的基本数据类型 四.我们以后如何获取包…

课设--学生成绩管理系统

欢迎来到 Papicatch的博客 文章目录 🍉技术核心 🍉引言 🍈标识 🍈背景 🍈项目概述 🍈 文档概述 🍉可行性分析的前提 🍈项目的要求 🍈项目的目标 🍈…

全面分析kimi和ChatGPT在论文写作方向的差别

学境思源,一键生成论文初稿: AcademicIdeas - 学境思源AI论文写作 Kimi和ChatGPT都是人工智能助手,致力于提供帮助和信息,但在论文写作方面,他们在下面几个方向的能力存在一些差别: 1. 语言支持&#xff…

英语学习笔记35——Our village

Our village 我们的村庄 词汇 Vocabulary photograph n. 照片 通常说:photo 复数:photos     picture 复数:pictures 搭配:take a photo 照相 以o结尾的单词复数es的: potato —— potatoes tomato —— tomatoe…

AI + Web3 Social Hackathon 来啦!报名参赛瓜分超 700,000+ 美元奖金池

“我们的目标是将 Web3 优质开发者聚集在一起,共同打造创新思维驱动的链上世界。无论你是经验丰富的开发者,还是刚踏上开发旅程的小白新手,都可以加入我们, 不断提升实战技能,让 AIWeb3 成为赋能未来的重要砝码。” 为…

DiffusionDet:用于物体检测的扩散模型

论文标题:DiffusionDet: Diffusion Model for Object Detection 论文地址:https://arxiv.org/pdf/2211.09788 DiffusionDet:用于物体检测的扩散模型 检测模型发展物体检测 DiffusionDet方法预备知识DiffusionDet前向扩散过程DiffusionDet反向…