当前位置:网站首页>牛客每日刷题之链表
牛客每日刷题之链表
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,
结语
兄弟们,一起来刷题嘎嘎的写题
边栏推荐
- 通讯录改进即“保存”
- [mysql database] the use of mysql database
- 滑动窗口篇
- 想要精准营销,从学习搭建一套对的标签体系开始丨DTVision分析洞察篇
- 进程和计划任务管理
- MATLAB图像处理入门
- command,shell,raw,script模块的作用和区别,file、copy、fetch、synchronize的应用
- Still don't know what business intelligence (BI) is?After reading this article, you will understand
- cglib获取不到接口注解
- 3.3V控制输出5V的方法
猜你喜欢
随机推荐
【计算机网络-哈工大】---学习笔记(下)---(一)网络安全、密码学基础、对称、公钥、身份认证、数字签名、KDC\CA
滑动窗口篇
Chapter7、基于图像的光照
Three Musketeers Advanced
RNN-T
LDO和DC-DC的区别
剑指Offer-双指针类型题目总结
Spark源码-任务提交流程-8-DAGScheduler任务切分
The request was rejected because the URL contained a potentially malicious String “//“
面向6G的大规模MIMO通信感知一体化:现状与展望
JDBC_PreparedStatement预编译对象
中断系统结构及中断控制详解
Still don't know what business intelligence (BI) is?After reading this article, you will understand
MATLAB图像处理入门
【计算机网络-哈工大】---学习笔记(下)---(二)Web安全威胁、SSL\IPsec、虚拟专用网、防火墙
feof它可不简单。
八、开发者工具与单元测试
图解LeetCode——761. 特殊的二进制序列(难度:困难)
通讯录改进即“保存”
屏:全贴合工艺之GF、GF2、G1F1、GG、TOL









