zoukankan      html  css  js  c++  java
  • Leetcode142 环形链表

    很多题解没有讲清楚非环部分的长度与相遇点到环起点那部分环之间为何是相等的这个数学关系。这里我就补充下为何他们是相等的。
    假设非环部分的长度是x,从环起点到相遇点的长度是y。环的长度是c。
    现在走的慢的那个指针走过的长度肯定是x+n1*c+y,走的快的那个指针的速度是走的慢的那个指针速度的两倍。这意味着走的快的那个指针走的长度是2(x+n1*c+y)。

    还有一个约束就是走的快的那个指针比走的慢的那个指针多走的路程一定是环长度的整数倍。根据上面那个式子可以知道2(x+n1*c+y)-x+n1*c+y=x+n1*c+y=n2*c。

    所以有x+y=(n2-n1)*c,这意味着什么?我们解读下这个数学公式:非环部分的长度+环起点到相遇点之间的长度就是环的整数倍。这在数据结构上的意义是什么?现在我们知道两个指针都在离环起点距离是y的那个相遇点,而现在x+y是环长度的整数倍,这意味着他们从相遇点再走x距离就刚刚走了很多圈,这意味着他们如果从相遇点再走x就到了起点。
    那怎么才能再走x步呢?答:让一个指针从头部开始走,另一个指针从相遇点走,等这两个指针相遇那就走了x步此时就是环的起点。

    class Solution {
    public:
        ListNode *detectCycle(ListNode *head) {
            ListNode *fast=head,*slow=head;
            while(fast!=NULL&&fast->next!=NULL)
            {
               fast=fast->next->next;
               slow=slow->next;
               if(fast==slow)
               {
                   slow=head;
                   while(slow!=fast)
                   {
                       slow=slow->next;
                       fast=fast->next;
                   }
                   return slow;
               }
            }
            return NULL;
        }
    };

    利用map键的唯一性,遍历链表,找到第一次重复的那个key,即是环的进口结点

    class Solution {
    public:
        ListNode *detectCycle(ListNode *head) {
            map<ListNode*,int>Map;
            ListNode*p=head;
            int index=0;
            while(p!=NULL&&p->next!=NULL)
            {
                if(Map.find(p)==Map.end())
                {
                   Map.insert(make_pair(p,index));
                   p=p->next;
                   index++;
                }
                  
                else
                    return p;
            }
            return NULL;
        }
    };
  • 相关阅读:
    关于IE缓存的解决方案(HTML,JSP,ASP,PHP,C#)(转)
    ASP.NET 2.0 中的客户端脚本
    Post和Get的区别(兼谈页面间传值的方式)(转)
    委托的小例子
    JS的正则表达式
    HTTP消息头
    asp.net一个onclick的全过程(简单写一下)
    location.reload() 和 location.replace()的区别和应用
    使用 .NET Framework 2.0 在您的应用程序中支持证书(转)
    页面动态注册脚本(小技巧)
  • 原文地址:https://www.cnblogs.com/renzmin/p/11875888.html
Copyright © 2011-2022 走看看