码迷,mamicode.com
首页 > 其他好文 > 详细

114 判断一个链表是否存在环并返回环起点

时间:2018-12-20 22:13:04      阅读:234      评论:0      收藏:0      [点我收藏+]

标签:==   list   fast   code   ptr   返回   save   ret   ext   

方法一 活用set

   ListNode *detectCycle(ListNode *head) {
        set<ListNode *> save;
        while (head != nullptr)
            if (save.find(head) != save.end())
                return *save.find(head);
            else {
                save.emplace(head);
                head = head->next;
            }
        return nullptr;
    }

方法二 快慢指针

    ListNode *detectCycle(ListNode *head) {
        if(head==nullptr)
            return nullptr;
        ListNode *slow = head, *fast = head;
        while(true){
            if(fast->next==nullptr||fast->next->next==nullptr)
                return nullptr;
            slow=slow->next;
            fast=fast->next->next;
            if(slow==fast){
                while(head!=fast){
                    head=head->next;
                    fast=fast->next;
                }
                return head;
            }
        }
    }

114 判断一个链表是否存在环并返回环起点

标签:==   list   fast   code   ptr   返回   save   ret   ext   

原文地址:https://www.cnblogs.com/INnoVationv2/p/10152627.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!