LeetCode刷题记录:(2)环形链表
2023-12-19 22:35:11
LeetCode传送阵
题目描述:
给定一个链表的头节点 head ,返回链表开始入环的第一个节点。
如果链表无环,则返回 null。
如果链表中有某个节点,可以通过连续跟踪 next 指针再次到达,则链表中存在环。
不允许修改 链表。
.
为了表示给定链表中的环,评测系统内部使用整数 pos 来表示链表尾连接到链表中的位置(索引从 0 开始)。如果 pos 是 -1,则在该链表中没有环。注意:pos 不作为参数进行传递,仅仅是为了标识链表的实际情况。
.
时间复杂度: O(n)
空间复杂度: O(1)
上代码:
public class Solution {
public ListNode detectCycle(ListNode head) {
ListNode fast = head, slow = head;
while(fast!=null && fast.next!=null){
slow = slow.next; // slow走一步
fast = fast.next.next; // fast走两步,相对slow走一步
// 如果slow可以追上fast则一定有环,反之亦然
if(slow == fast){
// 寻找入环节点
ListNode idx1 = slow; // idx1 标记相遇节点
ListNode idx2 = head; // idx2从头滑动,当与滑动的idx1 遇见时即为入环节点
while(idx1!=idx2){
idx1 = idx1.next;
idx2 = idx2.next;
}
return idx1;
}
}
return null;
}
}
重点说明:
在通过快慢指针确定有环后,为什么 idx1 与 idx2 相遇的节点就是入环节点?
.
文章来源:https://blog.csdn.net/weixin_45606831/article/details/135095467
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!