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