一、题目
函数原型:
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
相关推荐
8Qi87 分钟前
LeetCode 115 & 392:不同子序列 / 判断子序列小蒋学算法26 分钟前
算法-乘法表中第K小的数-二分智者知已应修善业35 分钟前
【51单片机8个LED,已经使用了D1D2,怎么样在不动D1D2的前提下实现D6~D8的流水灯】2024-1-19Evand J36 分钟前
【MATLAB例程】自适应渐消扩展卡尔曼滤波(AFEKF)三维雷达目标跟踪|效果已调优,附下载链接和运行结果,代码直接运行即可圣保罗的大教堂44 分钟前
leetcode 2161. 根据给定数字划分数组 中等插件开发1 小时前
矢量路径运算如何选GPU技术?——适用算法对比及OpenGL/Direct3D/CUDA选型指南8Qi81 小时前
LeetCode 72:编辑距离(Edit Distance)—— 题解SoftLipaRZC2 小时前
顺序表的应用:通讯录项目与经典算法实战8Qi82 小时前
LeetCode 583. 两个字符串的删除操作tigershang2 小时前
卡尔曼滤波:不确定世界中的最优估计