[leetcode] 142.环形链表2
给定一个链表,返回链表开始入环的第一个节点。 如果链表无环,则返回 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相关推荐
- LeetCode 142. 环形链表 II(Linked List Cycle II)
142. 环形链表 II 142. Linked List Cycle II 题目描述 给定一个链表,返回链表开始入环的第一个节点.如果链表无环,则返回 null. 为了表示给定链表中的环,我们使用整 ...
- LeetCode 142. 环形链表 II - Python 快慢指针法+详解
题目 142. 环形链表 II 难度中等761 给定一个链表,返回链表开始入环的第一个节点. 如果链表无环,则返回 null. 为了表示给定链表中的环,我们使用整数 pos 来表示链表尾连接到链表中的 ...
- LeetCode 142 环形链表 II
题目描述 给定一个链表,返回链表开始入环的第一个节点. 如果链表无环,则返回 null.为了表示给定链表中的环,我们使用整数 pos 来表示链表尾连接到链表中的位置(索引从 0 开 始). 如果 po ...
- LeetCode 142. 环形链表 II
LeetCode 给定一个链表,返回链表开始入环的第一个节点. 如果链表无环,则返回 null. 为了表示给定链表中的环,我们使用整数 pos 来表示链表尾连接到链表中的位置(索引从 0 开始). 如 ...
- LeetCode 142. 环形链表 II(链表环的检测)
文章目录 1. 题目链接 2. 解题 1. 题目链接 给定一个链表,返回链表开始入环的第一个节点. 如果链表无环,则返回 null. 为了表示给定链表中的环,我们使用整数 pos 来表示链表尾连接到链 ...
- LeetCode 142.环形链表||(中等)
题目描述 给定一个链表的头节点 head ,返回链表开始入环的第一个节点. 如果链表无环,则返回 null. 如果链表中有某个节点,可以通过连续跟踪 next 指针再次到达,则链表中存在环. 为了表 ...
- Leetcode 142. 环形链表 II (每日一题 20210902)
给定一个链表,返回链表开始入环的第一个节点. 如果链表无环,则返回 null.为了表示给定链表中的环,我们使用整数 pos 来表示链表尾连接到链表中的位置(索引从 0 开始). 如果 pos 是 -1 ...
- LeetCode 142——环形链表 II
1. 题目 2. 解答 2.1 方法 1 定义快慢两个指针,慢指针每次前进一步,快指针每次前进两步,若链表有环,则快慢指针一定会相遇. 当快慢指针相遇时,我们让慢指针指向头节点,快指针不变,然后每次快 ...
- LeetCode 142环形链表||-中等
给定一个链表,返回链表开始入环的第一个节点. 如果链表无环,则返回 null. 为了表示给定链表中的环,我们使用整数 pos 来表示链表尾连接到链表中的位置(索引从 0 开始). 如果 pos 是 - ...
最新文章
- softmax 与 logsoftmax 区别 或者说logsoftmax优点
- 用css3实现ps蒙版效果+动画
- Vtk读取并显示保存图像
- PostgreSQL函数如何返回数据集
- bzoj4773 负环
- a.pop啥意思python_python中pop什么意思
- 原来如此?修改浏览器滚动条样式
- Linux学习笔记002---Windows下安装CentOS7_带有UI桌面_图解
- 做游戏,学编程(C语言) 13 消灭星星
- Springboot项目启动时加载数据库数据到内存
- 物联网卡如何帮助农民提高收益
- 从食品质检员到代码工程师,大哥你就这样跳槽进了阿里巴巴?
- 好用的 curl 抓取 页面的封装函数
- 各省12.5m的Alos DEM数据的制作与分享
- Python npy文件
- NLP炼丹技巧:标签平滑label smoothing
- iOS设备的越狱方法
- Python使用struct处理二进制(pack和unpack用法)
- Chapter~3 Python基础
- 《Adobe Fireworks CS5中文版经典教程》——第1课 了解工作区 1.1 熟悉Adobe Fireworks...