怎样判断一个单链表是否有环?
问题:如何判断一个单链表是否有环?
解答:
- 可以把遍历过的结点用一个HashSet存储起来,然后没遍历一个新节点的时候就再去和HashSet中的元素做匹配。如果HashSet中已存在该结点,那么单链表有环。假设从单链表头结点到环入口结点的距离是D,单链表的环长是S。而每一次HashSet查找元素的时间复杂度是O(1),所以总体时间复杂度是1*(D+S)=D+S,可以简单理解为O(N),而算法的空间复杂度是D+S-1,可以简单理解为O(N)。所以这个算法的时间复杂度和空间复杂度都是O(N).
- 第二种思路就是创建两个变量slow和fast同时指向头节点,然后slow每次向后遍历一个结点,fast每次向后遍历两个结点,如果单链表没有环的话,那么slow将永远不会追上fast,而如果单链表有环的话slow就会追上fast.这个算法的时间复杂度和空间复杂度分别是O(N)和O(1).
__EOF__

本文作者:techgy
本文链接:https://www.cnblogs.com/techgy/p/14428385.html
关于博主:I am a good person
版权声明:本博客所有文章除特别声明外,均采用 BY-NC-SA 许可协议。转载请注明出处!
声援博主:如果您觉得文章对您有帮助,可以点击文章右下角【推荐】一下。您的鼓励是博主的最大动力!
本文链接:https://www.cnblogs.com/techgy/p/14428385.html
关于博主:I am a good person
版权声明:本博客所有文章除特别声明外,均采用 BY-NC-SA 许可协议。转载请注明出处!
声援博主:如果您觉得文章对您有帮助,可以点击文章右下角【推荐】一下。您的鼓励是博主的最大动力!
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· 从HTTP原因短语缺失研究HTTP/2和HTTP/3的设计差异
· 三行代码完成国际化适配,妙~啊~