两个链表相交,要求找出第一个相交的节点
来源:互联网 发布:网络作品著作权的保护 编辑:程序博客网 时间:2024/04/28 19:12
《编程之美》里面有一篇是讲如何判断两链表是否相交,读后觉得原文太过啰嗦。于是,笔者总结了一下,此类问题可以扩展为两大类,分别是:
1、单链表与环问题http://blog.csdn.net/liuxialong/archive/2011/06/20/6555850.aspx
2、单链表相交与环问题(本文)
给定两单链表A、B,只给出两头指针。请问:
1、如何判断两单链表(无环)是否相交?
有两种可取的办法:
(1)人为构环,将链表A的尾节点指向链表B,再判断是否构环成功?从链表B的头指针往下遍历,如果能够回到B,则说明相交
(2)判断两链表最后一个节点是否相同,如果相交,则尾节点肯定是同一节点
2、如何判断两单链表(不知是否有环)相交?
先判断是否有环,判断是否有环可以使用追逐办法,设置两个指针,一个走一步,一个走两步,如果能相遇则说明存在环
(1)两个都没环:回到问题1
(2)一个有环,一个没环:不用判断了,肯定两链表不相交
(3)两个都有环:判断链表A的碰撞点是否出现在链表B的环中,如果在,则相交。(相交时,环必定是两链表共有的)
3、如何寻找两相交链表(不知是否有环)的第一个相交节点?
同样,使用追逐办法先判断是否存在环,分情况讨论
(1)无环:人为构环,将链表A的尾节点指向链表B,则构成一个带环的单链表。这个问题就转换成寻找带环单链表的环入口节点。
解法参考:http://blog.csdn.net/liuxialong/archive/2011/06/20/6555850.aspx
(2)有环:计算出两链表的长度lA、lB,(环的长度和环到入口点长度之和就是链表长度)
计算带环链表长度,可参考http://blog.csdn.net/liuxialong/archive/2011/06/20/6555850.aspx
如果lA>lB,则链表A指针先走lA-lB,然后链表B指针开始走,两者相遇的点就是相交点
如果lB>lA,则链表B指针先走lB-lA,然后链表A指针开始走,两者相遇的点就是相交点
- 两个链表相交,要求找出第一个相交的节点
- 两个链表相交,要求找出第一个相交的节点
- 判断两个链表是否相交并找出第一个相交节点
- 寻找两个相交链表的第一个公共节点
- 寻找两个相交链表的第一个公共节点
- 寻找两个相交链表的第一个公共节点
- 判断两个链表是否相交及获得相交的第一个节点
- 求两个相交链表相交的第一个元素
- 两个单向链表,判断它们是否相交,若相交,找出它们的第一个公共的结点
- 链表:找出两个链表的相交节点
- 两个单向链表相交,找到第一个公共节点
- 已知有两个链表,判断它们是否相交,若相交求其第一个公共节点
- 寻找两个相交链表的第一个公共节点的问题
- 寻找两个相交的单链表的第一个节点
- 3.6 判断两个无环链表是否相交 & 找出相交的第一个结点
- 求两个相交链表的首个相交节点(转)
- 判断两个单链表是否相交同时找出第一个相交点(单链表是否有环及寻找入口节点)
- 如何求两个相交链表的第一个相交结点
- 工作介绍
- 简洁版string类
- 6.0.1 系统自带应用:时钟,源码编译问题
- JBoss AS domain模式配置
- 弹性运动之height的不适用
- 两个链表相交,要求找出第一个相交的节点
- 金融结算系统的基础业务之账户体系结构分析
- C++中类的四种构造函数
- Mimikatz小实验:黄金票据+dcsync dawner2016-08-26共26576人围观 ,发现 5 个不明物体
- NYOJ 915 +-字符串
- 贵人礼-中秋微信推广游戏
- json四中类型解析
- 使用flask-cache
- Gradle实战:不同编译类型的包同设备共存