LeetCode 热题100:160.相交链表

基础解法

时间复杂度O(m+n),空间复杂度O(m)

  1. 遍历其中一个链表,存储每个节点的地址;
  2. 遍历另一个链表,若节点在数组中已有该地址,则为第一个相交点。
javascript 复制代码
var getIntersectionNode = function (headA, headB) {
	let arr = [];
	let Intersected = null;
	//数组存储一个链表,判断引用类型值是否在数组里
	function traverseLink(head) {
		if (head == null) {
			return;
		}
		arr.push(head);
		return traverseLink(head.next);
	}

	traverseLink(headA);

	function Check(head) {
		if (head == null || Intersected !== null) {
			return;
		}
		if (arr.includes(head)) {
			Intersected = head;
		}
		return Check(head.next);
	}

	Check(headB);
	return Intersected;
};

进阶解法

时间复杂度O(m+n),空间复杂度O(1)

参照图片,链表A指针从开始到null,链表A步长 = 链表A独立节点步长 + 公共节点步长 + 空节点;

同理,链表B步长 = 链表B独立节点步长 + 公共节点步长 + 空节点。

则有: 链表A步长 + 链表B独立节点步长 == 链表B步长 +链表A独立节点步长。

根据这个思路,当A和B指针遍历到null,跳到对方的头节点,若两个节点相等,则一定交于同一个节点(最终一定交于null)。类似快慢指针的思路。

代码有:

javascript 复制代码
var getIntersectionNode = function (headA, headB) {
	let pointA = headA,
		PointB = headB;
	while (pointA !== PointB) {
		pointA = (pointA ? pointA.next : headB);
		PointB = (PointB? PointB.next : headA);
	}
	return pointA;
};
相关推荐
满分观察网友z3 分钟前
精准狙击:二叉树中的“左叶子”们与我的UI重构之旅(404. 左叶子之和)
算法
孟柯coding1 小时前
常见排序算法
数据结构·算法·排序算法
Point1 小时前
[LeetCode] 最长连续序列
前端·javascript·算法
是阿建吖!1 小时前
【优选算法】链表
数据结构·算法·链表
kev_gogo1 小时前
关于回归决策树CART生成算法中的最优化算法详解
算法·决策树·回归
叫我:松哥2 小时前
优秀案例:基于python django的智能家居销售数据采集和分析系统设计与实现,使用混合推荐算法和LSTM算法情感分析
爬虫·python·算法·django·lstm·智能家居·推荐算法
chenyy23334 小时前
2025.7.25动态规划再复习总结
算法·动态规划
爱和冰阔落4 小时前
【数据结构】长幼有序:树、二叉树、堆与TOP-K问题的层次解析(含源码)
c语言·数据结构·算法
zc.ovo6 小时前
图论水题日记
算法·深度优先·图论
某个默默无闻奋斗的人6 小时前
【矩阵专题】Leetcode48.旋转图像(Hot100)
java·算法·leetcode