LeetCode hot100-26

java 复制代码
142. 环形链表 II
给定一个链表的头节点  head ,返回链表开始入环的第一个节点。 如果链表无环,则返回 null。

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

不允许修改 链表。

这道题和25题基本一样啊。就直接用25题的思想秒了

java 复制代码
/**
 * Definition for singly-linked list.
 * class ListNode {
 * int val;
 * ListNode next;
 * ListNode(int x) {
 * val = x;
 * next = null;
 * }
 * }
 */
public class Solution {
    public ListNode detectCycle(ListNode head) {
        Set<ListNode> s = new HashSet<ListNode>();
        ListNode p = head;
        while (p != null) {
            if (!s.add(p)) {
                return p;
            }
            p = p.next;
        }
        return null;
    }
}

官方解法只想看哈希表的。挨着两个题它的解法略有不同,一个用contains判断,一个直接判断add的结果。我觉得还是后者简洁。

java 复制代码
public class Solution {
    public ListNode detectCycle(ListNode head) {
        ListNode pos = head;
        Set<ListNode> visited = new HashSet<ListNode>();
        while (pos != null) {
            if (visited.contains(pos)) {
                return pos;
            } else {
                visited.add(pos);
            }
            pos = pos.next;
        }
        return null;
    }
}

作者:力扣官方题解
链接:https://leetcode.cn/problems/linked-list-cycle-ii/solutions/441131/huan-xing-lian-biao-ii-by-leetcode-solution/
来源:力扣(LeetCode)
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
相关推荐
爱编码的傅同学19 分钟前
【今日算法】LeetCode 25.k个一组翻转链表 和 43.字符串相乘
算法·leetcode·链表
stolentime19 分钟前
P14978 [USACO26JAN1] Mooclear Reactor S题解
数据结构·c++·算法·扫描线·usaco
老歌老听老掉牙24 分钟前
差分进化算法深度解码:Scipy高效全局优化实战秘籍
python·算法·scipy
CSDN_RTKLIB28 分钟前
C++多元谓词
c++·算法·stl
LYS_061836 分钟前
寒假学习(2)(C语言2+模数电2)
c语言·学习·算法
listhi5201 小时前
压缩感知信号重构的块稀疏贝叶斯学习(BSBL)算法:原理、实现与应用
学习·算法·重构
摸个小yu1 小时前
【力扣LeetCode热题h100】哈希、双指针、滑动窗口
算法·leetcode·哈希算法
aloha_7891 小时前
乐信面试准备
java·spring boot·python·面试·职场和发展·maven
短剑重铸之日1 小时前
《RocketMQ研读》面试篇
java·后端·面试·职场和发展·rocketmq
充值修改昵称1 小时前
数据结构基础:B+树如何优化数据库性能
数据结构·b树·python·算法