两个链表的第一个公共结点——牛客offer
题目描述:
输入两个链表,找出它们的第一个公共结点。
题目分析:
只是数据域相同不是公共节点。公共结点代表该节点在两个链表中的数据域和指针域都是相同的,这意味着从该公共节点开始,后面的结点都是两个链表共有的,如图:
解题思路:
思路1:
从正序比较的角度来考虑:观察上图,链表1长度大于链表2,那么公共结点绝不可能存在于链表1比链表2多出来的那些结点中。基于这种想法,我们可以先求出两个链表的长度,然后现在长链表上遍历一段距离后,再开始同时遍历长链表和短链表并进行比较。
思路2:
从倒序比较的角度考虑:这个思路比较容易理解,因为两个链表的后面一部分是重复的,我们可以建立两个栈,将两个链表分别压入两个栈:
此时如果有栈是空的,说明无公共节点,返回null;
否则,循环取两个栈的栈顶元素进行比较:如果不相等,说明公共结点为该节点的下一个结点,否则循环直至有一个栈或两个栈为空终止:终止的原因有以下几条(1)如果两个栈都为空,说明是同一个链表,返回任意链表的头结点作为公共节点。例如{1,2,3} {1,2,3}(2)如果其中一个链表为空,说明短链表的全部元素都是和长链表共有的,则返回短链表的头结点。例如{1,2,3} {2,3}
测试:两者性能差不多,运行时间和占用空间相差无几。
代码实现:
思路1
public static ListNode FindFirstCommonNode(ListNode pHead1, ListNode pHead2) {
Stack<ListNode> stack1=new Stack<ListNode>();
Stack<ListNode> stack2=new Stack<ListNode>();
ListNode walkNode=pHead1;
while(walkNode!=null){
stack1.push(walkNode);
walkNode=walkNode.next;
}
walkNode=pHead2;
while(walkNode!=null){
stack2.push(walkNode);
walkNode=walkNode.next;
}
//当两个链表都为空链表时,无公共结点,返回null
if(stack1.size()==0||stack2.size()==0){
return null;
}
while(!stack1.empty()&&!stack2.empty()){
ListNode pop1=stack1.pop();
ListNode pop2=stack2.pop();
if(pop1!=pop2){
return pop1.next;
}
}
//当两个栈同时为空时,且没有出现非公共结点,说明两个链表是完全一样的
if(stack1.size()==0&&stack2.size()==0){
return pHead1; //return pHead2;
}
//当stack1先空时,说明链表1的所有结点和链表2都是公共的
else if(stack1.size()==0){
return pHead1;
}
//当stack2先空时,说明链表2的所有结点和链表1都是公共的
else{
return pHead2;
}
}
思路2
获取链表长度:
public static int getLength(ListNode pHead){
ListNode walkNode=pHead;
int length=0;
while(walkNode!=null){
length++;
walkNode=walkNode.next;
}
return length;
}
寻找公共结点:
public static ListNode FindFirstCommonNode(ListNode pHead1, ListNode pHead2) {
int n1=getLength(pHead1);
int n2=getLength(pHead2);
int lenDiff=n1>n2?(n1-n2):(n2-n1);
ListNode walkNode1=pHead1;
ListNode walkNode2=pHead2;
//将walkNode1与walkNode2对齐
if(n1>n2){
while(lenDiff>0){
lenDiff--;
walkNode1=walkNode1.next;
}
}
else{
while(lenDiff>0){
lenDiff--;
walkNode2=walkNode2.next;
}
}
//遍历比较
while(walkNode1!=null){
if(walkNode1==walkNode2){
return walkNode1;
}
walkNode1=walkNode1.next;
walkNode2=walkNode2.next;
}
return null;
}
主函数测试:
public static void main(String[]args){
ListNode phead1=new ListNode(1);
ListNode node11=new ListNode(2);
ListNode node12=new ListNode(3); ListNode phead2=new ListNode(4);
ListNode node21=new ListNode(5); ListNode node13=new ListNode(6);
ListNode node14=new ListNode(7); phead1.next=node11;
node11.next=node12;
node12.next=node13;
node13.next=node14;
phead2.next=node21;
node21.next=node13;
node13.next=node14;
System.out.print(FindFirstCommonNode(phead1,phead2).val);
}
两个链表的第一个公共结点——牛客offer的更多相关文章
- 九度OJ 1505 两个链表的第一个公共结点 【数据结构】
题目地址:http://ac.jobdu.com/problem.php?pid=1505 题目描述: 输入两个链表,找出它们的第一个公共结点. 输入: 输入可能包含多个测试样例. 对于每个测试案例, ...
- C++版 - 剑指offer之面试题37:两个链表的第一个公共结点[LeetCode 160] 解题报告
剑指offer之面试题37 两个链表的第一个公共结点 提交网址: http://www.nowcoder.com/practice/6ab1d9a29e88450685099d45c9e31e46?t ...
- 《剑指offer》第五十二题(两个链表的第一个公共结点)
// 面试题52:两个链表的第一个公共结点 // 题目:输入两个链表,找出它们的第一个公共结点. #include <iostream> #include "List.h&quo ...
- 【剑指offer】两个链表的第一个公共结点,C++实现
原创文章,转载请注明出处! 博客文章索引地址 # 题目 #举例 如果两个单向链表有公共的节点,那么这两个链表从第一个公共结点开始,之后所有结点都是重合的,不可能再出现分叉.拓扑结构如下图所示: # 思 ...
- 剑指Offer - 九度1505 - 两个链表的第一个公共结点
剑指Offer - 九度1505 - 两个链表的第一个公共结点2013-11-24 20:09 题目描述: 输入两个链表,找出它们的第一个公共结点. 输入: 输入可能包含多个测试样例.对于每个测试案例 ...
- 编程算法 - 两个链表的第一个公共结点 代码(C)
两个链表的第一个公共结点 代码(C) 本文地址: http://blog.csdn.net/caroline_wendy 题目: 输入两个链表, 找出它们的第一个公共结点. 计算链表的长度, 然后移动 ...
- php实现找两个链表的第一个公共结点(实例演示)
php实现找两个链表的第一个公共结点(实例演示) 一.总结 因为是链表,第一个节点公共之后,后面所有的节点都公共了 画个图实例演示一下,会超清晰且简单 二.php实现找两个链表的第一个公共结点 题目描 ...
- 剑指Offer(三十六):两个链表的第一个公共结点
剑指Offer(三十六):两个链表的第一个公共结点 搜索微信公众号:'AI-ming3526'或者'计算机视觉这件小事' 获取更多算法.机器学习干货 csdn:https://blog.csdn.ne ...
- 【剑指offer】面试题 52. 两个链表的第一个公共结点
面试题 52. 两个链表的第一个公共结点 NowCoder 题目描述 输入两个链表,找出它们的第一个公共结点. Java 实现 ListNode Class class ListNode { int ...
随机推荐
- How to do Deep Learning on Graphs with Graph Convolutional Networks
翻译: How to do Deep Learning on Graphs with Graph Convolutional Networks 什么是图卷积网络 图卷积网络是一个在图上进行操作的神经网 ...
- Java中boolean类型占用多少个字节?我说一个,面试官让我回家等通知
摘自:https://www.cnblogs.com/qiaogeli/p/12004962.html 程序员乔戈里 腾讯面试官问我Java中boolean类型占用多少个字节?我说一个,面试官让我回家 ...
- Java和python中的面向对象
Python与Java中的示例类 Java类是在与类同名的文件中定义的.因此,必须将该类保存在一个名为Car.java的文件中.每个文件中只能定义一个类. public class Car { pri ...
- Nginx之编写HTTP模块
1. 常用数据结构 1.1 ngx_str_t typedef struct { /* * 字符串的有效长度 */ size_t len; /* * 有效字符串的起始地址,该字符串通常并不以'\0'结 ...
- 9Patch图
NinePatch是一种很有用的PNG图片格式,它可以在特定区域随文字大小进行缩放. - 上边线控制水平拉伸- 左边线控制竖直拉伸- 右边线和下边线控制内容区域 如下: 背景图片的中间区域会随着文字的 ...
- [Ubuntu]18安装百度网盘
1.下载客户端 下载地址: 选择linux版本,我选择的是deb格式,下载就可以了. 2.安装 进入下载目录,点击右键,选择在终端打开. 之后输入 以下代码愉快的安装就好了 注意:dpkg后面跟的文 ...
- 001-软件架构概览、maven补充【分包工程、合并包、web容器插件】、git补充
一.整体概述 1.1.共性问题 技术瓶颈.不成体系.不能实际使用.不能落地.无法入门 1.2.目标-软件架构 专注于构建:高可扩展.高性能.大数据量.高并发.分布式的系统架构. 各项技术.组合构建分布 ...
- jsp+UEditor粘贴word
最近公司做项目需要实现一个功能,在网页富文本编辑器中实现粘贴Word图文的功能. 我们在网站中使用的Web编辑器比较多,都是根据用户需求来选择的.目前还没有固定哪一个编辑器 有时候用的是UEditor ...
- Scrapy+redis实现分布式爬虫
概述 什么是分布式爬虫 需要搭建一个由n台电脑组成的机群,然后在每一台电脑中执行同一组程序,让其对同一网络资源进行联合且分布的数据爬取. 原生Scrapy无法实现分布式的原因 原生Scrapy中调度器 ...
- lua学习笔记4--XLua
下载XLua: https://github.com/tencent/xlua 项目中使用XLua只需将Plugins和XLua两个文件夹拷贝到U3D中即可XLua只是核心,用于实现Lua和C#交 ...