?作者简介:我是18shou,一名即将秋招的java实习生
?个人主页:_18shou
🔥系列专栏:牛客刷题专栏
📃推荐一款模拟面试、刷题神器👉?在线刷题面经模拟面试
目录
描述
解析
?复杂度
📃结语
描述
输入两个无环的单向链表,找出它们的第一个公共结点, 如果没有公共节则返回空。(注意因为传入数据是链表, 所以错误测试数据的提示是用 其他方式显示的,保证传入数据是正确的) 数据范围: n < 1000 要求:空间复杂度0(1),时间复杂度0(n)
解析
使用两个指针N1,N2,一个从链表1的头节点开始遍历,我们记为N1,一个从链表2的头节点开始遍历,我们记为N2. 让N1和N2一起遍历,当N1先走完链表1的尽头(为null) 的时候,则从链表2的头节点继续遍历,同样,如果N2先走完了链表2的尽头,则从链表1 的头节点继续遍历,也就是说,N1和N2都会遍历链表1和链表2。 因为两个指针,同样的速度,走完同样长度 (链表1+链表2), 不管两条链表有无相同节点,都能够到达同时到达终点。 (N1最后肯定能到达链表2的终点,N2肯定能到达链表1的终点)。 所以,如何得到公共节点: ●有公共节点的时候,N1和N2必会相遇,因为长度一 样嘛,速度也一定,必会走到相同的地方的,所以当两者相等的时候,则会第一 个公共的节 点 ●无公共节点的时候,此时N1和N2则都会走到终点,那么他们此时都是null,所以也算是相等了。
代码 ?
import java.util.*;
public class Solution {
public ListNode FindFirstCommonNode(ListNode a, ListNode b) {
Deque<ListNode> d1 = new ArrayDeque<>(), d2 = new ArrayDeque<>();
while (a != null) {
d1.add(a);
a = a.next;
}
while (b != null) {
d2.add(b);
b = b.next;
}
ListNode ans = null;
while (!d1.isEmpty() && !d2.isEmpty() && d1.peekLast() == d2.peekLast()) {
ans = d1.pollLast();
d2.pollLast();
}
return ans;
}
}
?复杂度
?空间复杂度0(1),时间复杂度0(n,
📃结语
兄弟们,一起来刷题👉嘎嘎的写题
|