力扣hot100:相交链表

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

输入:intersectVal = 8, listA = [4,1,8,4,5], listB = [5,6,1,8,4,5], skipA = 2, skipB = 3

输出:Intersected at '8'

解题思路:

我们将每个链表分为两部分,不相交部分和相交部分C

那么listA = A+C listB = B+C 他们的总长度为:A+C+B = B+C+A

所以我们只要找出两个节点相等的地方就是交点,因为他们只要相交的话一定会相遇的

逐步演示双指针过程

假设listA = [4,1,8] listB = [5,6,1,8]

复制代码
初始状态`
`pA -> 4`
`pB -> 5`

`第1步:`
`pA = 4, pB = 5,不相等`
`pA = pA.next = 1`
`pB = pB.next = 6`

`第2步`
`pA = 1, pB = 6,不相等`
`pA = pA.next = 8`
`pB = pB.next = 1`

`第3步`
`pA = 8, pB = 1,不相等`
`pA = pA.next = None (链表A结束)`
`pB = pB.next = 8`

`第4步`
`pA = None, pB = 8,不相等`
`pA = headB = 5 (切换到链表B)`
`pB = pB.next = None`

`第5步`
`pA = 5, pB = None,不相等`
`pA = pA.next = 6`
`pB = headA = 4 (切换到链表A)`

`第6步`
`pA = 6, pB = 4,不相等`
`pA = pA.next = 1`
`pB = pB.next = 1`

`第7步`
`pA = 1, pB = 1,相等 ✓ 找到相交节点!`

`
复制代码
// 定义链表节点类`
`class ListNode {`
`    constructor(val) {`
`        this.val = val;`
`        this.next = null;`
`    }`
`}`

`function getIntersectionNode (headA,headB){`
`    if(!headA || !headB) return null;`
`    let nodeA = headA`
`    let nodeB = headB`
`    while(nodeA !== nodeB ){`
`        nodeA = nodeA !== null ? nodeA.next : headB`
`        nodeB = nodeB !== null ? nodeB.next : headA`
`    }`
`    return nodeA`
`}`

`// 示例:手动创建链表并传入`
`// 创建 listA: 4 -> 1 -> 8 -> 4 -> 5`
`let a1 = new ListNode(4);`
`let a2 = new ListNode(1);`
`let a3 = new ListNode(8);`
`let a4 = new ListNode(4);`
`let a5 = new ListNode(5);`
`a1.next = a2;`
`a2.next = a3;`
`a3.next = a4;`
`a4.next = a5;`

`// 创建 listB: 5 -> 6 -> 1 -> 8 -> 4 -> 5`
`let b1 = new ListNode(5);`
`let b2 = new ListNode(6);`
`let b3 = new ListNode(1);`
`let b4 = new ListNode(8);`
`let b5 = new ListNode(4);`
`let b6 = new ListNode(5);`
`b1.next = b2;`
`b2.next = b3;`
`b3.next = b4;`
`b4.next = b5;`
`b5.next = b6;`

`// 设置相交点:listA 的第3个节点(8)与 listB 的第4个节点(8)相交`
`// 实际上是 listB 的第4个节点指向 listA 的第3个节点`
`b4.next = a3; // b4 (8) -> a3 (8)`

`let headA = a1;`
`let headB = b1;`

`console.log(getIntersectionNode(headA, headB)?.val); // 输出 8`
`
相关推荐
会编程的土豆2 小时前
【leetcode hot 100】二叉树
算法·leetcode
Jay叶湘伦2 小时前
【极简】用 Vue 写一个 ChatGPT 前端应用,支持连续对话、Markdown 渲染与本地记忆
前端·vue.js·chatgpt
大家的林语冰2 小时前
《前端周刊》尤大官宣 Vite 8 稳定版首发!npm 新官网?React 官网更新。focusgroup 新功能!
前端·javascript·vite
kuuailetianzi2 小时前
构建企业级督办任务系统:Vue3 + TypeScript 实战(多级任务拆解+批量操作+进度追踪+单元格合并)
前端·javascript·typescript
Hilaku2 小时前
王自如公开招聘全栈前端,要求有多离谱?
前端·javascript·ai编程
罗湖老棍子3 小时前
花神游历各国(信息学奥赛一本通- P1550)(洛谷-P4145)
数据结构·算法·线段树·势能数·区间开平方根 区间查询
大漠_w3cpluscom3 小时前
CSS 技巧:CSS 中选择 html 元素的各种奇技淫巧
前端·css·weui
Mr_Xuhhh3 小时前
LeetCode 热题 100 刷题笔记:数组与排列的经典解法(续)
算法·leetcode·职场和发展
炽烈小老头3 小时前
【每天学习一点算法 2026/03/29】搜索二维矩阵 II
学习·算法·矩阵