当前位置: 首页 > news >正文

惠州网站建设制作志愿服务网站建设中标公告

惠州网站建设制作,志愿服务网站建设中标公告,室内设计需要学哪些软件,中国生意网LeetCode 热题 100 | 160. 相交链表 大家好,今天我们来解决一道经典的算法题——相交链表。这道题在LeetCode上被标记为简单难度,要求我们找到两个单链表相交的起始节点。如果两个链表没有相交,则返回 null。下面我将详细讲解解题思路&#…

LeetCode 热题 100 | 160. 相交链表

大家好,今天我们来解决一道经典的算法题——相交链表。这道题在LeetCode上被标记为简单难度,要求我们找到两个单链表相交的起始节点。如果两个链表没有相交,则返回 null。下面我将详细讲解解题思路,并附上Python代码实现。


问题描述

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

注意

  • 题目数据保证整个链式结构中不存在环。
  • 函数返回结果后,链表必须保持其原始结构。

示例:

输入:intersectVal = 8, listA = [4,1,8,4,5], listB = [5,6,1,8,4,5], skipA = 2, skipB = 3
输出:Intersected at '8'
解释:
链表 A 为 [4,1,8,4,5],链表 B 为 [5,6,1,8,4,5]。
在 A 中,相交节点前有 2 个节点;在 B 中,相交节点前有 3 个节点。

解题思路

核心思想
  1. 双指针法

    • 使用两个指针 pApB,分别从 headAheadB 开始遍历链表。
    • pA 到达链表末尾时,将其重定向到 headB;当 pB 到达链表末尾时,将其重定向到 headA
    • 如果两个链表相交,pApB 会在相交节点相遇;如果不相交,pApB 会同时到达链表末尾(null)。
  2. 数学原理

    • 设链表 A 的长度为 m,链表 B 的长度为 n,相交部分长度为 c
    • 如果两个链表相交,pApB 分别遍历 m + n - c 步后会相遇。

Python代码实现

class ListNode:def __init__(self, x):self.val = xself.next = Nonedef getIntersectionNode(headA, headB):if not headA or not headB:return NonepA, pB = headA, headB# 遍历链表,直到两个指针相遇或同时到达末尾while pA != pB:# 如果 pA 到达末尾,重定向到 headBpA = pA.next if pA else headB# 如果 pB 到达末尾,重定向到 headApB = pB.next if pB else headA# 返回相遇节点(如果相交)或 None(如果不相交)return pA

代码解析

  1. 初始化指针

    • pApB 分别指向 headAheadB
  2. 遍历链表

    • pApB 不相等时,继续遍历。
    • 如果 pA 到达链表末尾,将其重定向到 headB
    • 如果 pB 到达链表末尾,将其重定向到 headA
  3. 返回结果

    • 如果两个链表相交,pApB 会在相交节点相遇。
    • 如果两个链表不相交,pApB 会同时到达链表末尾(null)。

复杂度分析

  • 时间复杂度:O(m + n),其中 mn 分别是链表 A 和链表 B 的长度。两个指针最多遍历 m + n 个节点。
  • 空间复杂度:O(1),只使用了常数个额外空间。

示例运行

示例1
输入:
intersectVal = 8, listA = [4,1,8,4,5], listB = [5,6,1,8,4,5], skipA = 2, skipB = 3
输出:Intersected at '8'
解释:
链表 A 为 [4,1,8,4,5],链表 B 为 [5,6,1,8,4,5]。
在 A 中,相交节点前有 2 个节点;在 B 中,相交节点前有 3 个节点。
示例2
输入:
intersectVal = 2, listA = [1,9,1,2,4], listB = [3,2,4], skipA = 3, skipB = 1
输出:Intersected at '2'
解释:
链表 A 为 [1,9,1,2,4],链表 B 为 [3,2,4]。
在 A 中,相交节点前有 3 个节点;在 B 中,相交节点前有 1 个节点。
示例3
输入:
intersectVal = 0, listA = [2,6,4], listB = [1,5], skipA = 3, skipB = 2
输出:No intersection
解释:
链表 A 为 [2,6,4],链表 B 为 [1,5]。
这两个链表不相交,因此返回 null。

总结

通过双指针法,我们可以高效地找到两个链表的相交节点。这种方法不仅简洁,而且效率非常高,适合处理类似的问题。希望这篇题解对大家有所帮助,如果有任何问题,欢迎在评论区留言讨论!

关注我,获取更多算法题解和编程技巧!

http://www.dtcms.com/a/529098.html

相关文章:

  • 资料分析-年均与乘积增长率
  • 视频网站用什么做的济南网站建设山东聚搜网推荐
  • Minecraft合集
  • 公司网页网站建设sae wordpress 图片
  • 网站建设读后感为什么网页不能打开建设银行网站
  • 百度网站流量查询南京房地产网站建设
  • 南安梅山建设银行网站长春快速建站模板
  • CSMA/CA 协议和CSMA/CD的区别
  • 网络自动化:Ansible/Netmiko 网络设备批量配置与管理
  • 探索聊天机器人系统提示的秘密[特殊字符]
  • 接近光速运动下的光速不变性:基于张祥前统一场论的推导与验证
  • 固始网站制作四川德充建设集团有限公司网站
  • STM32G474单片机开发入门(二十七)HRTIME高精度定时器的PWM(50KHZ)输出实战
  • Windows磁盘占用率高解决记录
  • 泛用性而言,系统分析师 与 信息系统项目管理工程师 比较
  • 网站程序国内 wordpress主题
  • 太仓公司网站建设电话天津企业网站建设方案
  • AI 浏览器技术趋势分析:Perplexity Comet 的创新与早期用户激励机制探讨
  • 4.基础开发工具(一)
  • 网站如何调用微博wordpress 发布视频
  • SQL注入第一步:数据库类型判断
  • 软件架构师个人总结笔记
  • 免费发做网站怎么申请网站空间域名
  • 建设旅游网站的功能定位seo网站排名优化方案
  • 龙岗网站设计案例网站是什么字体
  • 《锁侠闯江湖:小白通关Java synchronized底层秘境》
  • 广州网站制作公司排名寿光网站优化
  • Python如何写Selenium全攻略
  • 【大模型的原理 - 从输入到输出】Transformer 的 Decoder-only 架构
  • 网站建设前置审批网站配色主题