(转)求单链表是否有环,环入口和环长

Posted wrencai

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了(转)求单链表是否有环,环入口和环长相关的知识,希望对你有一定的参考价值。

转自:http://www.cnblogs.com/youxin/p/3303172.html

1.链表中是否有环的判断
可以设置两个指针(fast,slow),初始值均指向头,slow每次向前一步,fast每次向前两步;
如果链表中有环,则fast先进入环中,而slow后进入环中,两个指针在环中必定相遇;
如果fast遍历到尾部为NULL,则无环
2.链表有环,判断环的入口点
  当fast若与slow相遇时,slow肯定没有走遍历完链表,而fast已经在环内循环了n圈(1<=n)。假设slow走了s步,则fast走了2s步(fast步数还等于s 加上在环上多转的n圈),设环长为r,则:

2s = s + nr
s= nr

设整个链表长L,入口环与相遇点距离为x,起点到环入口点的距离为a。
a + x = nr
a + x = (n – 1)r +r = (n-1)r + L - a
a = (n-1)r + (L – a – x)

(L – a – x)为相遇点到环入口点的距离,由此可知,从链表头到环入口点等于(n-1)循环内环+相遇点到环入口点
 

以上是关于(转)求单链表是否有环,环入口和环长的主要内容,如果未能解决你的问题,请参考以下文章

数据结构与算法判断一个单链表是否有环及环入口

单链表是否有环及环入口点

线性表练习之Example048-判断一个单链表是否有环,如果有则找出环的入口点并返回,否则返回 NULL

判断链表中是否有环 ----- 有关单链表中环的问题

单链表 --- 环相关问题(是否存在环是否相交)

单链表的环入口,环大小,解环