剑指offer-两个链表的第一个公共节点-JavaScript
题目形容:输入两个链表,找出它们的第一个公共节点。
解法 1: 遍历+哈希表记录
比较容易想到的思路:
- 开拓哈希表 map。key 是节点,value 是 boolean,代表节点能否出现过
- 对 list1 进行遍历,设置
map[节点]=true - 对 list2 进行遍历,假如节点在 map 中出现过,那么说明这是两个链表的公共节点,返回
代码实现如下:
// ac地址:https://leetcode-cn.com/problems/liang-ge-lian-biao-de-di-yi-ge-gong-gong-jie-dian-lcof/// 原文地址:https://xxoo521.com/2020-03-12-list-node//** * @param {ListNode} headA * @param {ListNode} headB * @return {ListNode} */var getIntersectionNode = function(headA, headB) { const map = new Map(); let node = headA; while (node) { map.set(node, true); node = node.next; } node = headB; while (node) { if (map.has(node)) return node; node = node.next; } return null;};时间复杂度是,空间复杂度是
。
解法 2: 快慢指针
题目提醒了,空间复杂度可以降低到。这时候不能用哈希表,可以使用快慢指针的思路来解决。整体思路如下:
- 遍历得到两个链表的长度,以及长度差 diff
- 将慢指针 slow 指向较长链表,快指针 fast 指向较短链表
- slow 向前移动 diff 个距离
- slow 和 fast 同时向前移动,每次移动一个距离。若存在公共节点,那么它们肯定会遇上。
代码实现是:
// ac地址:https://leetcode-cn.com/problems/liang-ge-lian-biao-de-di-yi-ge-gong-gong-jie-dian-lcof/// 原文地址:https://xxoo521.com/2020-03-12-list-node//** * @param {ListNode} headA * @param {ListNode} headB * @return {ListNode} */var getIntersectionNode = function(headA, headB) { let node = headA; let lengthA = 0; while (node) { ++lengthA; node = node.next; } if (!lengthA) return null; node = headB; let lengthB = 0; while (node) { ++lengthB; node = node.next; } if (!lengthB) return null; let diff = 0, slow, fast; if (lengthA > lengthB) { slow = headA; fast = headB; diff = lengthA - lengthB; } else { slow = headB; fast = headA; diff = lengthB - lengthA; } while (diff--) { slow = slow.next; } while (slow !== fast) { slow = slow.next; fast = fast.next; } return slow;};时间复杂度是,空间复杂度是
。效果也蛮好的,时间击败 95.49%,内存击败 100%。截图如下:
image
更多资料
整理不易,若对您有帮助,请给个「关注+点赞」,您的支持是我升级的动力 ??
- ??Blog:剑指 Offer 题解 + JS 代码
- ??Github : dongyuanxin/blog
- ?? 公众号:心谭博客
说明
1. 本站所有资源来源于用户上传和网络,如有侵权请邮件联系站长!
2. 分享目的仅供大家学习和交流,您必须在下载后24小时内删除!
3. 不得使用于非法商业用途,不得违反国家法律。否则后果自负!
4. 本站提供的源码、模板、插件等等其他资源,都不包含技术服务请大家谅解!
5. 如有链接无法下载、失效或广告,请联系管理员处理!
6. 本站资源售价只是摆设,本站源码仅提供给会员学习使用!
7. 如遇到加密压缩包,请使用360解压,如遇到无法解压的请联系管理员
开心源码网 » 剑指offer-两个链表的第一个公共节点-JavaScript
1. 本站所有资源来源于用户上传和网络,如有侵权请邮件联系站长!
2. 分享目的仅供大家学习和交流,您必须在下载后24小时内删除!
3. 不得使用于非法商业用途,不得违反国家法律。否则后果自负!
4. 本站提供的源码、模板、插件等等其他资源,都不包含技术服务请大家谅解!
5. 如有链接无法下载、失效或广告,请联系管理员处理!
6. 本站资源售价只是摆设,本站源码仅提供给会员学习使用!
7. 如遇到加密压缩包,请使用360解压,如遇到无法解压的请联系管理员
开心源码网 » 剑指offer-两个链表的第一个公共节点-JavaScript