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)
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
相关推荐
想要AC的sjh23 分钟前
【Leetcode】3159. 查询数组中元素的出现位置
数据结构·算法·leetcode
虽千万人 吾往矣26 分钟前
golang LeetCode 热题 100(技巧)-更新中
算法·leetcode·职场和发展
南宫生29 分钟前
力扣-数据结构-4【算法学习day.75】
java·数据结构·学习·算法·leetcode
fks14333 分钟前
leetcode 354. 俄罗斯套娃信封问题
leetcode
chenziang134 分钟前
leetcode hot 100搜索回溯
算法·leetcode·职场和发展
TANGLONG22236 分钟前
【初阶数据结构与算法】八大排序算法之归并排序与非比较排序(计数排序)
java·数据结构·c++·算法·面试·蓝桥杯·排序算法
m0_6949380141 分钟前
Leetcode打卡:查询数组中元素出现的位置
算法·leetcode·职场和发展
坊钰1 小时前
【Java 数据结构】LinkedList 类 和 模拟实现链表
java·开发语言·数据结构·学习·算法·链表
RS_数模加油站1 小时前
第十六届“蓝桥杯”全国软件和信息技术专业人才大赛简介及资料大全
职场和发展·蓝桥杯
还下着雨ZG1 小时前
C++实战:手撕类似于vector的容器(逆序算法、排序算法等)
c++·算法