一、题目
函数原型:
bool hasCycle(struct ListNode *head)
二、算法判断不是环形链表,只需遍历链表找到空结点即可。
判断是环形链表,由于链表是环形的,遍历不会永远不会结束。所以要设置快慢指针,慢指针一次走一步,快指针一次走两步。当两个指针都进入环时,快指针走地比慢指针快,因此快指针总会遇到慢指针。因此,判断是环形链表的条件是慢指针等于快指针。
三、代码
cppbool hasCycle(struct ListNode *head) { struct ListNode *fast=head; struct ListNode *slow=head; while(fast&&fast->next) { fast=fast->next->next; slow=slow->next; if(fast==slow) return true; } return false; }
leetcode:141. 环形链表
南林yan2023-11-08 20:02
相关推荐
海兰4 分钟前
【实用程序】电商销售分析仪表盘 — 从零搭建一个AI参与的全栈数据洞察系统zwenqiyu38 分钟前
P5283 [十二省联考 2019] 异或粽子题解wayz1138 分钟前
Momentum:TSI(真实强度指数)技术指标详解万事大吉CC1 小时前
Python 笔试输入模板总结lihao lihao1 小时前
Linux信号大白话_NOI2 小时前
【洛谷 P2249】查找(深基 13. 例 1)+ 详细分析吠品2 小时前
C++实现m行n列带边框的长方形输出智者知已应修善业2 小时前
【51单片机2个外部中断显示中断历时,初始化8左移3位共阳数码管】2024-6-6西安邮电大学2 小时前
分治算法详细讲解code bean2 小时前
平衡相关性与多样性:推荐系统中的永恒博弈与 MMR 算法详解