【力扣100】142.环形链表2

添加链接描述

python 复制代码
# Definition for singly-linked list.
# class ListNode:
#     def __init__(self, x):
#         self.val = x
#         self.next = None

class Solution:
    def detectCycle(self, head: Optional[ListNode]) -> Optional[ListNode]:
        # 思路是使用set,如果这个节点在set出现过,记录这个节点,并循环出这个节点的下标
        if head is None or head.next is None:
            return None
        visited=set()
        index=0
        while head:
            if head in visited:
                mynode=head
                return mynode
            visited.add(head)
            head=head.next
        return None

        

思路:

  1. 跟环形链表1不同的是,这道题需要返回的值是成环的第一个元素
  2. 所以选择set记录每一个节点,set的本质是哈希表,查询时间复杂度是O(1)
相关推荐
千金裘换酒5 分钟前
LeetCode 删除链表的倒数第N个结点
算法·leetcode
SweetCode17 分钟前
【无标题】
开发语言·c++·算法
shughui22 分钟前
Python基础面试题:语言定位+数据类型+核心操作+算法实战(含代码实例)
开发语言·python·算法
王老师青少年编程32 分钟前
信奥赛C++提高组csp-s之拓扑排序详解
c++·算法·拓扑排序·csp·信奥赛·csp-s·提高组
kaikaile199541 分钟前
matlab计算流场
人工智能·算法·matlab
老鼠只爱大米1 小时前
LeetCode算法题详解 42:接雨水
leetcode·动态规划·双指针·单调栈·接雨水·雨水收集
3GPP仿真实验室1 小时前
【Python源码】6G:PyTorch OFDM 教学仿真平台
算法
xie_pin_an1 小时前
C++ 从入门到进阶:核心知识与实战指南
java·c++·算法
我是个菜鸡.1 小时前
多模态算法面经准备
算法
AlenTech1 小时前
739. 每日温度 - 力扣(LeetCode)
算法·leetcode·职场和发展