美文网首页
链表--环形链表

链表--环形链表

作者: 习惯水文的前端苏 | 来源:发表于2022-02-13 18:17 被阅读0次

    \bullet 目录

    \bullet 环形链表一

    \bullet 思路

        使用快慢指针,在无环的情况下,快指针一定先到达链表尾,否则,快慢指针将最终在环内一直循环下去,但有一个时间点会相遇

    \bullet 实现

    \bullet 环形链表二

    \bullet 思路

        由上一题可知,存在环时,l和r一定会在某一点相遇

        由于我们每次让r的移动距离是l的两倍,故两点在相遇时,r走过的总距离也为l的两倍

        则如图

        l走过的距离为:a+b

        r走过的距离为:a+n(b+c)+b

        根据距离关系,可知

            2(a+b) = a+n(b+c)+b

            则

            a=c+(n−1)(b+c)

        即

            a=c

        则当两点相遇时,a从head出发,c从r触发,两点将在入环处相遇

    \bullet 实现

    相关文章

      网友评论

          本文标题:链表--环形链表

          本文链接:https://www.haomeiwen.com/subject/fniflrtx.html