一、题目
函数原型:
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
相关推荐
中國龍在廣州6 分钟前
谈谈2025年人工智能现状及发展趋势分析C雨后彩虹20 分钟前
二维伞的雨滴效应一路往蓝-Anbo21 分钟前
C语言从句柄到对象 (八) —— 当对象会说话:观察者模式与事件链表youngee111 小时前
hot100-60子集郝学胜-神的一滴1 小时前
Linux线程属性设置分离技术详解Timmylyx05181 小时前
2025年最后一搏—— Educational Codeforces Round 186 (Rated for Div. 2) 题解微光闪现1 小时前
国际航班动态提醒与延误预测优选平台指南leoufung1 小时前
LeetCode 120. Triangle:从 0 分到 100 分的思考过程(含二维 DP 与空间优化)gihigo19982 小时前
基于反步法的路径追踪控制Jim-2ha02 小时前
【JavaScript】常见排序算法实现