一、题目
函数原型:
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
相关推荐
stsdddd7 小时前
【YOLO算法包裹背包行李箱塑料袋包装纸盒快递盒带目标检测数据集】洛水水7 小时前
【力扣100题】52.最小路径和快手技术7 小时前
将DSA注意力引入多模态,快手Keye2.0开启强化推理新范式圣保罗的大教堂7 小时前
leetcode 3043. 最长公共前缀的长度 中等码之气三段.7 小时前
牛客周赛 Round 145-E(写了200行的史山)Hwang2527 小时前
Attention-04-decoder部分计算机安禾7 小时前
【算法分析与设计】第13篇:最小生成树:Prim算法与Kruskal算法的比较研究vortex57 小时前
国密(商用密码)算法核心参数速查wuweijianlove8 小时前
算法中的记忆化思想与重复子问题优化的技术5小江的记录本9 小时前
【JVM虚拟机】垃圾回收GC:垃圾判定算法:引用计数法、可达性分析算法(附《思维导图》+《面试高频考点清单》)