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

Posted INnoVation-V2

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了114 判断一个链表是否存在环并返回环起点相关的知识,希望对你有一定的参考价值。

方法一 活用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 判断一个链表是否存在环并返回环起点的主要内容,如果未能解决你的问题,请参考以下文章

通俗易懂的告诉你如何判断链表中是否有环并找出环的入口位置

通俗易懂的告诉你如何判断链表中是否有环并找出环的入口位置

python代码检测链表中的环并删除环

判断链表中是否存在环表(Java版)

判断单向链表是否有环,环起点,环长,链表长

[leetcode] 判断链表是否有环及其变式