当前位置:网站首页>牛客每日刷题之链表
牛客每日刷题之链表
2022-08-09 05:38:00 【_18shou】
作者简介:我是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,
结语
兄弟们,一起来刷题嘎嘎的写题
边栏推荐
猜你喜欢
随机推荐
command,shell,raw,script模块的作用和区别,file、copy、fetch、synchronize的应用
Storage System Architecture Evolution
保存Simulink仿真模型为图片或者PDF的方法
力扣202-快乐数——哈希集合
The development trend of software testing
进程和计划任务管理
Openresty执行lua脚本
面向6G的欠采样相移键控可见光调制方案
Eureka-Server------单节和集群的搭建
shell function
RT201 Domestic PA RF Power Amplifier Compatible with RFX2401C
明明加了唯一索引,为什么还是产生重复数据?
Oracle02-sql学习(单表查询,exists子查询,函数入门)
dsafasfdasfasf
Distributed timing task framework xxl-job source code analysis
什么是SIP请求和SIP响应?
Software testing method is introduced in detail
matlab simulink球杆控制系统的模糊PID控制设计
学习一下 常说的节流
HAL库的使用之Cube配置编码器输入捕获模式