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;
}
};

最新文章

  1. 【grunt第一弹】30分钟学会使用grunt打包前端代码
  2. 使用 Fiddler 上传微信公众账号 自定义菜单
  3. html_博客博主
  4. 为什么正常安装并成功运行了Genymotion虚拟但是运行的时候启动的却是自带的模拟器?
  5. BZOJ2809——[Apio2012]dispatching
  6. DedeCMS模板文件不存在,无法解析文档! 问题定位方法
  7. Unix无缓冲文件操作函数、文件信息查询
  8. C++算术运算符与算术表达式
  9. 老问题:Android子线程中更新UI的3种方法
  10. C# Expression表达式笔记
  11. python抓取NBA现役球员基本信息数据
  12. Python IDLE 代码高亮主题
  13. ul li 的 float:left;
  14. C#自定义控件的创建
  15. Trailing Zeroes (I) LightOJ - 1028(求因子个数)
  16. [OpenGL]纹理贴图实现 总结
  17. oracle通过profile限制用户的恶意登录和使用期限
  18. 线性规划费用流解法(Bzoj1061: [Noi2008]志愿者招募)
  19. scala当中的类型参数
  20. springmvc传递有特殊字符的路径参数

热门文章

  1. ajax以及文件上传的几种方式
  2. [转]python开发_shelve_完整版
  3. 关于Relay Log无法自动删除的问题
  4. 线段树 Mayor's posters
  5. Educational Codeforces Round 31
  6. 【HTML/XML 2】XML基础知识点总结
  7. javascript数组学习1
  8. 最小的图灵完备语言——BrainFuck
  9. 深入了解类加载过程及Java程序执行顺序
  10. annotation之@Autowired、@Inject、@Resource三者区别