一、题目
函数原型:
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
相关推荐
Chase_______12 小时前
【算法】删除子数组的最大得分 & 最多 K 个重复元素的最长子数组——不定长滑动窗口与哈希频率约束fie888913 小时前
城市环境下车辆目标跟踪算法 MATLAB 实现tryCbest13 小时前
软考 - 排序算法AKA__Zas13 小时前
芝士算法(双指针篇 1.0)吃着火锅x唱着歌13 小时前
LeetCode 726.原子的数量君义_noip13 小时前
CSP-S 2025 提高级 第一轮(初赛) 阅读程序(3)玛卡巴卡ldf13 小时前
【LeetCode 手撕算法】(栈)有效括号、最小栈、字符串解码、每日温度、柱状图最大矩形happyprince13 小时前
05-FlagEmbedding 评估模块详解wuweijianlove13 小时前
算法优化的多目标平衡与性能建模研究的技术7_深海凉_13 小时前
LeetCode热题100-两两交换链表中的节点