给定一个链表,返回链表开始入环的第一个节点。 如果链表无环,则返回 null。

为了表示给定链表中的环,我们使用整数 pos 来表示链表尾连接到链表中的位置(索引从 0 开始)。 如果 pos 是 -1,则在该链表中没有环。注意,pos 仅仅是用于标识环的情况,并不会作为参数传递到函数中。

说明:不允许修改给定的链表。

进阶:

  • 你是否可以使用 O(1) 空间解决此题?

示例 1:

输入:head = [3,2,0,-4], pos = 1
输出:返回索引为 1 的链表节点
解释:链表中有一个环,其尾部连接到第二个节点。

示例 2:

输入:head = [1,2], pos = 0
输出:返回索引为 0 的链表节点
解释:链表中有一个环,其尾部连接到第一个节点。

示例 3:

输入:head = [1], pos = -1
输出:返回 null
解释:链表中没有环。

提示:

  • 链表中节点的数目范围在范围 [0, 104] 内
  • -105 <= Node.val <= 105
  • pos 的值为 -1 或者链表中的一个有效索引

1.暴力解法

class Solution:def detectCycle(self, head: ListNode) -> ListNode:visited = set()curr = headwhile curr != None:if curr in visited:return currelse:visited.add(curr)curr = curr.next

2.快慢指针

class Solution:def detectCycle(self,head:ListNode)->ListNode:fast = headslow = headwhile fast != None and fast.next != None:fast = fast.next.nextslow = slow.nextif fast==slow:breakif fast ==None or fast.next ==None:return Nonecur=headwhile cur != slow:cur = cur.nextslow = slow.nextreturn cur

[leetcode] 142.环形链表2相关推荐

  1. LeetCode 142. 环形链表 II(Linked List Cycle II)

    142. 环形链表 II 142. Linked List Cycle II 题目描述 给定一个链表,返回链表开始入环的第一个节点.如果链表无环,则返回 null. 为了表示给定链表中的环,我们使用整 ...

  2. LeetCode 142. 环形链表 II - Python 快慢指针法+详解

    题目 142. 环形链表 II 难度中等761 给定一个链表,返回链表开始入环的第一个节点. 如果链表无环,则返回 null. 为了表示给定链表中的环,我们使用整数 pos 来表示链表尾连接到链表中的 ...

  3. LeetCode 142 环形链表 II

    题目描述 给定一个链表,返回链表开始入环的第一个节点. 如果链表无环,则返回 null.为了表示给定链表中的环,我们使用整数 pos 来表示链表尾连接到链表中的位置(索引从 0 开 始). 如果 po ...

  4. LeetCode 142. 环形链表 II

    LeetCode 给定一个链表,返回链表开始入环的第一个节点. 如果链表无环,则返回 null. 为了表示给定链表中的环,我们使用整数 pos 来表示链表尾连接到链表中的位置(索引从 0 开始). 如 ...

  5. LeetCode 142. 环形链表 II(链表环的检测)

    文章目录 1. 题目链接 2. 解题 1. 题目链接 给定一个链表,返回链表开始入环的第一个节点. 如果链表无环,则返回 null. 为了表示给定链表中的环,我们使用整数 pos 来表示链表尾连接到链 ...

  6. LeetCode 142.环形链表||(中等)

    题目描述 给定一个链表的头节点  head ,返回链表开始入环的第一个节点. 如果链表无环,则返回 null. 如果链表中有某个节点,可以通过连续跟踪 next 指针再次到达,则链表中存在环. 为了表 ...

  7. Leetcode 142. 环形链表 II (每日一题 20210902)

    给定一个链表,返回链表开始入环的第一个节点. 如果链表无环,则返回 null.为了表示给定链表中的环,我们使用整数 pos 来表示链表尾连接到链表中的位置(索引从 0 开始). 如果 pos 是 -1 ...

  8. LeetCode 142——环形链表 II

    1. 题目 2. 解答 2.1 方法 1 定义快慢两个指针,慢指针每次前进一步,快指针每次前进两步,若链表有环,则快慢指针一定会相遇. 当快慢指针相遇时,我们让慢指针指向头节点,快指针不变,然后每次快 ...

  9. LeetCode 142环形链表||-中等

    给定一个链表,返回链表开始入环的第一个节点. 如果链表无环,则返回 null. 为了表示给定链表中的环,我们使用整数 pos 来表示链表尾连接到链表中的位置(索引从 0 开始). 如果 pos 是 - ...

最新文章

  1. softmax 与 logsoftmax 区别 或者说logsoftmax优点
  2. 用css3实现ps蒙版效果+动画
  3. Vtk读取并显示保存图像
  4. PostgreSQL函数如何返回数据集
  5. bzoj4773 负环
  6. a.pop啥意思python_python中pop什么意思
  7. 原来如此?修改浏览器滚动条样式
  8. Linux学习笔记002---Windows下安装CentOS7_带有UI桌面_图解
  9. 做游戏,学编程(C语言) 13 消灭星星
  10. Springboot项目启动时加载数据库数据到内存
  11. 物联网卡如何帮助农民提高收益
  12. 从食品质检员到代码工程师,大哥你就这样跳槽进了阿里巴巴?
  13. 好用的 curl 抓取 页面的封装函数
  14. 各省12.5m的Alos DEM数据的制作与分享
  15. Python npy文件
  16. NLP炼丹技巧:标签平滑label smoothing
  17. iOS设备的越狱方法
  18. Python使用struct处理二进制(pack和unpack用法)
  19. Chapter~3 Python基础
  20. 《Adobe Fireworks CS5中文版经典教程》——第1课 了解工作区 1.1 熟悉Adobe Fireworks...

热门文章

  1. MyBatis(五)MyBatis整合Spring原理分析
  2. Apache Kafka 不需要管理员:删除 Apache ZooKeeper 的依赖
  3. SQL 性能优化梳理 —— 基本概念、创建时优化、查询时优化
  4. 并发环境下,先操作数据库还是先操作缓存?
  5. 学会查看 RabbitMQ日志
  6. JAVA多线程之扩展ThreadPoolExecutor
  7. 流媒体的未来——视频技术如何演变
  8. 圆桌对话:数字化升级,视频通信云赋能全行业
  9. 首届全球互联网通信云大会重磅来袭 融云邀您洞见通信未来
  10. Linux I/O 那些事儿