判断单链表是否有环及环的链接点
2015-07-14 15:39
316 查看
问题:
给定一个单链表,只给出头指针h:
1、如何判断是否存在环?
2、如何知道环的长度?
3、如何找出环的连接点在哪里?
4、带环链表的长度是多少?
解法:
1、对于问题1,使用追赶的方法,设定两个指针slow、fast,从头指针开始,每次分别前进1步、2步。如存在环,则两者相遇;如不存在环,fast遇到NULL退出。
2、对于问题2,记录下问题1的碰撞点p,从碰撞点开始遍历,再次走到碰撞点所用的操作数就是环的长度s。
3、问题3:有定理:碰撞点p到连接点的距离=头指针到连接点的距离,因此,分别从碰撞点、头指针开始走,相遇的那个点就是连接点。(证明在后面附注)
4、问题3中已经求出连接点距离头指针的长度,加上问题2中求出的环的长度,二者之和就是带环单链表的长度
代码:
证明:
假设单链表的总长度为L,头结点到环入口的距离为a,环入口到快慢指针相遇的结点距离为x,环的长度为r,慢指针总共走了s步,则快指针走了2s步。另外,快指针要追上慢指针的话快指针至少要在环里面转了一圈多(假设转了n圈加x的距离),得到以下关系:
s = a + x;
2s = a + nr + x;
=>a + x = nr;
=>a = nr - x;
由上式可知:若在头结点和相遇结点分别设一指针,同步(单步)前进,则最后一定相遇在环入口结点。
给定一个单链表,只给出头指针h:
1、如何判断是否存在环?
2、如何知道环的长度?
3、如何找出环的连接点在哪里?
4、带环链表的长度是多少?
解法:
1、对于问题1,使用追赶的方法,设定两个指针slow、fast,从头指针开始,每次分别前进1步、2步。如存在环,则两者相遇;如不存在环,fast遇到NULL退出。
2、对于问题2,记录下问题1的碰撞点p,从碰撞点开始遍历,再次走到碰撞点所用的操作数就是环的长度s。
3、问题3:有定理:碰撞点p到连接点的距离=头指针到连接点的距离,因此,分别从碰撞点、头指针开始走,相遇的那个点就是连接点。(证明在后面附注)
4、问题3中已经求出连接点距离头指针的长度,加上问题2中求出的环的长度,二者之和就是带环单链表的长度
代码:
证明:
假设单链表的总长度为L,头结点到环入口的距离为a,环入口到快慢指针相遇的结点距离为x,环的长度为r,慢指针总共走了s步,则快指针走了2s步。另外,快指针要追上慢指针的话快指针至少要在环里面转了一圈多(假设转了n圈加x的距离),得到以下关系:
s = a + x;
2s = a + nr + x;
=>a + x = nr;
=>a = nr - x;
由上式可知:若在头结点和相遇结点分别设一指针,同步(单步)前进,则最后一定相遇在环入口结点。
相关文章推荐
- 获取枚举的title
- JAVA 环境变量配置
- CMake + VS2013 Win7x64下编译opencv3.0
- iOS 7中实现模糊效果教程
- LintCode Search a 2D matrix 搜索二维矩阵
- Double-Buffer双缓冲——游戏编程模式(下)
- 解决jsp 文件加载过大的问题
- 【VBA研究】如何将单元格数据赋给数组
- ap6234移植
- 巧用JVM启动参数定位一个问题
- Linux上的常用软件
- sha1加密
- 深入了解java同步、锁紧机构
- Hibernate(四)主键属性
- 百度地图滑动冲突的问题解决
- RecyclerView 的分割线(divider)--DividerItemDecoration
- 全局变量关键字global的使用
- Android应用Activity、Dialog、PopWindow、Toast窗口添加机制及源码分析 《二》
- 协同过滤算法实战
- POJ 2739 Sum of Consecutive Prime Numbers-数论-(连续素数和)