当前位置: 首页 > news >正文

【每天学习一点算法 2025/12/15】环形链表

每天学习一点算法 2025/12/15

题目:环形链表

给你一个链表的头节点 head ,判断链表中是否有环。

如果链表中有某个节点,可以通过连续跟踪 next 指针再次到达,则链表中存在环。 为了表示给定链表中的环,评测系统内部使用整数 pos 来表示链表尾连接到链表中的位置(索引从 0 开始)。注意:pos 不作为参数进行传递 。仅仅是为了标识链表的实际情况。

如果链表中存在环 ,则返回 true 。 否则,返回 false 。

  1. 首先想到的方法就是用Map存储节点,如果遇到重复的节点说明有环。

    functionhasCycle(head:ListNode|null):boolean{if(!head||!head.next)returnfalse;constmap=newMap();while(head){if(map.has(head.next))returntrue;map.set(head,head.val);head=head.next;}returnfalse;};
  2. 「Floyd 判圈算法」(又称龟兔赛跑算法)、

    Floyd 判圈算法(Floyd’s Tortoise and Hare Algorithm)是一种空间复杂度为 O (1)的算法,用于检测链表、迭代序列等结构中是否存在环,并能找到环的入口点,核心思想是通过快慢指针的移动规律来判断环的存在。

    • 定义两个指针:慢指针(龟)每次移动 1 步,快指针(兔)每次移动 2 步。
    • 若结构中无环:快指针会先到达终点(如链表的null)。
    • 若结构中有环:快慢指针最终会在环内某个节点相遇(因为快指针在环内 “追赶” 慢指针,且步长差为 1,必然会追上)。
    functionhasCycle(head:ListNode|null):boolean{if(!head||!head.next)returnfalse;letslow:ListNode|null=head;letfast:ListNode|null=head.next;while(slow!==fast){if(!fast||!fast.next)returnfalse;slow=slow?.next||null;fast=fast.next.next;}returntrue;}

题目来源:力扣(LeetCode)

http://www.cnnetsun.cn/news/61347.html

相关文章:

  • DDR5和DDR4比有什么区别,值得升级吗?
  • 海尔智能设备HomeAssistant接入完整教程
  • 大学生,不狠下心来学习,就等着被卷出局!
  • 350M参数颠覆行业:Liquid AI轻量翻译模型重塑日英互译格局
  • 幼儿园组织结构图绘制 保教团队分工可视化
  • 40、vi 和 Vim 编辑器命令全解析
  • 42、Vile 9.6 选项设置与常见问题解决指南
  • UniHacker终极指南:免费解锁Unity完整开发环境的简单方法
  • 软考-系统集成项目管理工程师案例简答题
  • 如何快速掌握TradingVue.js:专业交易图表库的完整指南 [特殊字符]
  • 4.2 技术文档自动生成:从代码到专业文档的转化
  • FMEA在软件可靠性测试中的实践与应用
  • Playwright MCP在UI自动化测试中的定位与思考
  • 友达 G170ETN02.1 工业液晶显示屏:17.0 英寸超宽温高亮度场景的显示驱动技术解析
  • Harmony之路:服务卡片——打造桌面上的“原子化服务“
  • JVM内存模型详解
  • 源启高校・郑航站圆满落幕!鸿蒙 6.0 适配实战 + 职业机遇双赋能,解锁开源新可能
  • 腾讯混元大模型开源:520亿激活参数改写行业效率标准
  • 计算机专业毕业=码农?网络安全正在重塑你的职业天花板
  • 120亿参数颠覆智能体市场:GLM-4.5-Air-FP8如何重新定义企业AI效率标准
  • Forget-Me-Not: 建议采用一种简单的提示技术,防止在长时间的提示中遗忘信息
  • 数据处理服务:G1/ZGC如何提升稳定性
  • 18、使用 Neutron 创建独立路由器
  • 什么是回溯算法
  • 7、OpenStack网络配置与Linux桥接网络详解
  • Web服务器性能优化终极指南:快速提升响应时间
  • 古城景区管理|基于springboot + vue古城景区管理系统(源码+数据库+文档)
  • 腾讯开源HunyuanVideo-Avatar:一张照片+14秒音频,开启数字人创作全民时代
  • AI提示词实战技巧:从新手到专家的五个关键突破
  • agsXMPP使用