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;
        }
    };
  • 相关阅读:
    asp.net membership 修改密码
    linq直接执行sql语句
    word-wrap,word-break,white-space,text-overflow的区别和用法
    ObjectQuery查询及方法
    HTML 标签的 enctype 属性
    【C#学习笔记】类构造函数使用
    【C#学习笔记】播放wav文件
    【C#学习笔记】类型转换
    【C#学习笔记】函数重载
    【C#学习笔记】读文件
  • 原文地址:https://www.cnblogs.com/renzmin/p/11875888.html
Copyright © 2011-2022 走看看