经典OJ题:单链表相交

目录

题目:

链表相交🍌的概念:

单链表相交🍌主要的问题:

思路的分析🍌:

问题的回答:

如何判断相交🍌:

如何寻找交点🍌:

代码演示分析:


题目:

有两个链表A、B,如果链表相交,返回链表A、B相交的节点,如果不相交返回NULL

题源: 160. 相交链表 - 力扣(LeetCode)

链表相交🍌的概念:

对于链表相交,更具单链表的特性,链表相交应该呈现的是一个Y型图或者一个U型图,但却对不是一个X型图。

如图,是一个X型图,这种图是错误的!并不是属于单链表相交!

单链表相交🍌主要的问题:

  1. 如何判断是否相交?
  2. 如何寻找相交的交点?

思路的分析🍌:

假如设立两个指针,分别指向当前节点的下一个节点,并且判断两个节点的空间地址是否一样,当空间地址一样时,便找到了交点。

但是!这种解法的局限性是当A、B两个链表的长度不一样时,我们会错过相交的节点部分。

又假设,设立两个指针,分别指向两两个链表的节点,并且判断两个节点中的数据是否一样,如果一样,则找到了交点,但是链表中的数据并没有说明是不重复的,很容易出现错误,如下图所示。

暴力求解法,使用指针对链表A的节点进行遍历,使用另一个指针,指向链表B的节点,用链表A中的每一个节点对链表B的每一个节点进行对比判断,判断空间地址是否一样。

但是暴力求解法的最坏的结果就是二者没有焦点,但是A中的所有节点都要和B中的所有节点进行判断,这导致了时间复杂度因为操作的频繁性抵达了最高------两个链表都要遍历,且都要重复进行判断对比,导致时间复杂度变成了O(N^2)

问题的回答:

如何判断相交🍌:

如果相交那么链表A和链表B的尾节点一定是同一个空间地址!或者说二者的尾节点相等!

如何寻找交点🍌:

我们可以更具距离差,来拉开两个指针走向交点的时间。

也就是说,设立两个指针前,得出两个链表的长度,之后算出长度差

然后将较长的那个链表设置为long指针指向,然后long指针先再这个链表中走出对应的长度差后,和另一个指针short一起按照相同的速度朝前走,并且同时进行对比判断,当两个指针指向的空间地址一样时,那么返回指针,得出相交的节点。

代码演示分析:

相关推荐
爱喝水的鱼丶2 分钟前
SAP-ABAP:SAP基础数据校验工具开发系列博客(共5篇)第五篇:性能优化与上线运维:保障高并发场景下的工具稳定运行
运维·学习·性能优化·sap·abap·erp·经验交流
zzz_23684 分钟前
【Spring】面试突击系列(一):IoC 与 DI 深度解析
java·spring·面试
stolentime4 分钟前
CF2066D1 Club of Young Aircraft Builders (easy version)题解
c++·算法·动态规划·组合数学
nashane5 分钟前
HarmonyOS 6学习:NFC服务中IsoDep连接失败的排查与解决——从参数匹配到多SDK协同的完整指南
学习·华为·harmonyos
Dillon Dong7 分钟前
【风电控制】高低穿现场失败的原因分析——算法简单但工程复杂
算法·变流器·风电控制·dfig
于先生吖8 分钟前
前后端分离体育服务项目,场馆计费+线下赛事排行小程序部署开发教程
java·小程序·uni-app
闪电悠米18 分钟前
黑马点评-秒杀优化-01_async_seckill_idea
java·数据库·ide·redis·分布式·缓存·intellij-idea
小欣加油18 分钟前
leetcode41 缺失的第一个正数
数据结构·c++·算法·leetcode
摇滚侠18 分钟前
IDEA 创建 Java 项目 lib 和 resources
java·ide·intellij-idea
悠哉悠哉愿意18 分钟前
【单片机复习笔记】十五届国赛复盘
笔记·单片机·嵌入式硬件·学习