linked-list-cycle-ii——链表,找出开始循环节点
2024-08-24 11:40:49
Given a linked list, return the node where the cycle begins. If there is no cycle, returnnull.
Follow up:
Can you solve it without using extra space?
快慢指针找重合判断是否循环、而后fast从头开始+1,slow继续前进直到重合
思路解析:
首先我们看一张图;
设:链表头是X,环的第一个节点是Y,slow和fast第一次的交点是Z。各段的长度分别是a,b,c,如图所示。环的长度是L。第一次相遇时slow走过的距离:a+b,fast走过的距离:a+b+c+b。因为fast的速度是slow的两倍,有 2(a+b) = a+b+c+b,可以得到a=c。让两个指针分别从X和Z开始走,每次走一步,那么正好会在Y相遇!也就是环的第一个节点。
/**
* Definition for singly-linked list.
* struct ListNode {
* int val;
* ListNode *next;
* ListNode(int x) : val(x), next(NULL) {}
* };
*/
class Solution {
public:
ListNode *detectCycle(ListNode *head) {
if(head==NULL)
return NULL;
ListNode *fast=head,*slow=head;
ListNode *res=NULL;
while(fast!=NULL&&fast->next!=NULL){
fast=fast->next->next;
slow=slow->next;
if(fast==slow){
res=fast;
break;
}
}
if(res==NULL)
return res; fast=head;
while(fast!=res){
fast=fast->next;
res=res->next;
}
return res;
}
};
最新文章
- 【grunt第一弹】30分钟学会使用grunt打包前端代码
- 使用 Fiddler 上传微信公众账号 自定义菜单
- html_博客博主
- 为什么正常安装并成功运行了Genymotion虚拟但是运行的时候启动的却是自带的模拟器?
- BZOJ2809——[Apio2012]dispatching
- DedeCMS模板文件不存在,无法解析文档! 问题定位方法
- Unix无缓冲文件操作函数、文件信息查询
- C++算术运算符与算术表达式
- 老问题:Android子线程中更新UI的3种方法
- C# Expression表达式笔记
- python抓取NBA现役球员基本信息数据
- Python IDLE 代码高亮主题
- ul li 的 float:left;
- C#自定义控件的创建
- Trailing Zeroes (I) LightOJ - 1028(求因子个数)
- [OpenGL]纹理贴图实现 总结
- oracle通过profile限制用户的恶意登录和使用期限
- 线性规划费用流解法(Bzoj1061: [Noi2008]志愿者招募)
- scala当中的类型参数
- springmvc传递有特殊字符的路径参数
热门文章
- ajax以及文件上传的几种方式
- [转]python开发_shelve_完整版
- 关于Relay Log无法自动删除的问题
- 线段树 Mayor's posters
- Educational Codeforces Round 31
- 【HTML/XML 2】XML基础知识点总结
- javascript数组学习1
- 最小的图灵完备语言——BrainFuck
- 深入了解类加载过程及Java程序执行顺序
- annotation之@Autowired、@Inject、@Resource三者区别