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;
};
相关推荐
代码游侠38 分钟前
日历的各种C语言实现方法
c语言·开发语言·学习·算法
春日见5 小时前
丝滑快速拓展随机树 S-RRT(Smoothly RRT)算法核心原理与完整流程
人工智能·算法·机器学习·路径规划算法·s-rrt
Code小翊5 小时前
”回调“高级
算法·青少年编程
云里雾里!5 小时前
力扣 977. 有序数组的平方:双指针法的优雅解法
算法·leetcode·职场和发展
一只侯子8 小时前
Face AE Tuning
图像处理·笔记·学习·算法·计算机视觉
jianqiang.xue8 小时前
别把 Scratch 当 “动画玩具”!图形化编程是算法思维的最佳启蒙
人工智能·算法·青少年编程·机器人·少儿编程
不许哈哈哈8 小时前
Python数据结构
数据结构·算法·排序算法
J***79399 小时前
后端在分布式系统中的数据分片
算法·哈希算法
Dream it possible!10 小时前
LeetCode 面试经典 150_二叉搜索树_二叉搜索树中第 K 小的元素(86_230_C++_中等)
c++·leetcode·面试
sin_hielo11 小时前
leetcode 2872
数据结构·算法·leetcode