Leetcode-141.环形链表

dict和set

1. 结构上的区别:

类型键(Key)值(Value)示例
dict{'a': 1, 'b': 2}
set没有{'a', 'b'}
  • dict 是**键值对(key-value)**的集合。

  • set只有键(key)没有值的一组唯一元素。


2. 用途上的区别:

  • dict 用于建立键与值的映射,例如地址到位置、用户名到ID等。

  • set 用于快速查找是否存在去重集合运算等,例如判断某个元素是否出现过。


3. 操作上的区别:

dict 常见操作:
d = {'x': 1, 'y': 2}
d['z'] = 3             # 添加键值对
value = d.get('x')     # 查找键对应的值
del d['y']             # 删除键值对
set 常见操作:
s = {'a', 'b'}
s.add('c')             # 添加元素
s.remove('a')          # 删除元素
exists = 'b' in s      # 判断是否存在

4. 底层实现的共同点和不同点:

  • 相同点:都使用哈希表,所以查找、插入、删除的时间复杂度平均为 O(1)O(1)。

  • 不同点:

    • dict 哈希表存储的是 (key, value) 对,插入更复杂。

    • set 只存 key,没有 value,占用空间略小,操作略快。


image.png


---```python
# Definition for singly-linked list.# class ListNode:#     def __init__(self, x):#         self.val = x#         self.next = None
class Solution:def hasCycle(self, head: Optional[ListNode]) -> bool:seen=set()while head:if head in seen:return Trueseen.add(head)head=head.nextreturn False

思路:

利用集合 seen 记录遍历过程中出现过的节点引用(即内存地址)。若遍历某个节点时发现它已经在 seen 中,说明这个节点之前已经访问过,即链表存在环。否则,将当前节点加入集合并继续向后遍历。


🧠解题过程:

  1. 创建一个空集合 seen

  2. 从头节点 head 开始,逐个遍历每个节点;

  3. 如果当前节点 head 已存在于 seen 中,说明链表出现了环,返回 True

  4. 否则将当前节点加入集合,继续向下一个节点遍历;

  5. 若遍历到 None,说明链表无环,返回 False

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/web/91781.shtml
繁体地址,请注明出处:http://hk.pswp.cn/web/91781.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

调节步进电机速度时调PSC和调ARR的区别

在步进电机控制中,调节速度通常是通过改变脉冲频率实现的。代码中选择调节ARR(Auto-Reload Register)而非PSC(Prescaler)的原因如下: 1. ARR 与 PSC 的核心区别 • ARR(自动重载寄存器&#xff…

在 AKS 中运行 Azure DevOps 私有代理-1

简介 配置 Azure DevOps 私有代理的传统方法是将其部署在虚拟机 (VM) 上。然而,一个有趣的替代方案是利用 Azure Kubernetes 服务 (AKS) 来实现此目的。 本文将指导您如何使用 Helm Chart 在 AKS 集群中设置 Azure DevOps 私有代理,并提供该过程的分步说明。 在 AKS 中部署…

C# _Json数据

目录 1、添加Json库 2、数据序列化(对象转 JSON)和反序列化(JSON 转对象)操作 3、序列化 创建和读取Json数据 创建Json数据 定义一个CreateJson方法 读取 解析 Json数据 定义一个ReadJson方法 4、程序运行结果 在 C# 中&…

JavaScript 原始值与引用值

JavaScript 原始值与引用值 ECMAScript变量可以包含两种不同类型的数据:原始值和引用值。 原始值(primitive value)就是最简单的数据,引用值(reference value)则是由多个值构成的对象。 保存原始值的变量是…

linux中挂载磁盘和卸载

查找磁盘 找到你想要挂载的磁盘。可以使用lsblk或fdisk -l命令来查看系统中所有的磁盘和分区信息。 lsblk 对数据盘进行分区 在fdisk交互界面里,按以下步骤操作 fdisk /dev/vdb- 输入n来创建新分区。 - 按照提示设置分区的起始扇区、结束扇区等信息,…

java8学习笔记-Stream流

JDK1.8新增了Stream类,从而把函数式编程的风格引入到Java语言中,Stream类的API提供了强大的功能,使用Stream后,可以写出更加强大,更加简洁的代码首先,Stream流有一些特性:Stream流不是一种数据结…

Flutter开发 dart语言基本语法

特点 Dart语言支持JIT与AOT。 Dart语言采用单线程模型。 Dart语言是强类型编程语言,但是允许弱类型语言式编程。 基本语法 1.变量和常量 变量 var、object、dynamic关键字或数据类型显式声明变量。 命名规则: 变量名称必须由数字、字母、下划线或$组成&a…

SpringBoot:基于 Redis 自定义注解实现后端接口防重复提交校验(幂等操作)

SpringBoot:基于 Redis 自定义注解实现后端接口防重复提交校验(幂等操作)可基于 时间间隔 和 用于幂等判断的参数名称 实现防重复提交校验 客户端发送请求 ↓ [Spring Boot 应用入口]↓ ┌─────────────────────────…

【语音技术】意图与语料

目录 1. 意图 1.1. 意图分类 1.1.1 入口意图(Entry Intent) 1.1.2 对话意图(Dialog Intent) 1.2. 意图类型切换操作步骤 2. 语料 2.1 语料分类详解 2.2 语料编写规范详解 2.3 标签符号深度说明 3. 词槽 3.1 符类型要求 …

【MySQL集群架构与实践5】使用Docker实现水平分片

目录 一. 在Docker中安装ShardingSphere 二. 实践:水平分片 2.1 应用场景 2.2 架构图 2.3 服务器规划 2.4 创建server-user容器 2.5 创建server-order0和server-order1容器 2.6.日志配置 2.7 数据节点配置 2.8.测试数据节点 2.8.1.测试server_order0.t_or…

视觉图像处理中级篇 [1]—— 彩色照相机的效果与预处理

在工业检测中,黑白相机虽应用广泛,但在应对颜色差异检测时往往力不从心。彩色照相机凭借其对色彩信息的精准捕捉,成为复杂场景下的理想选择,而预处理技术则进一步释放了其性能潜力。一、彩色照相机的效果检查盖子上的金色标签可以…

使用 BERT 的 NSP 实现语义感知切片 —— 提升 RAG 系统的检索质量

在构建 Retrieval-Augmented Generation(RAG)系统时,文档的切片方式至关重要。我们需要将长文本切分成合适的段落(chunks),然后存入向量数据库进行召回。如果切得太粗,会丢失上下文细节&#xf…

使用STM32CubeMX生成的STM32CubeIDE工程在更改工程名后编译失败问题解决

0 问题描述 使用STM32CubeMX生成STM32CubeIDE工程,然后使用STM32CubeIDE改名后编译提示如下错误: 1 问题原因及解决办法 1.1 问题原因 原因在于更名后STM32CubeIDE没有自动更新引用关系,这是因为我们使用STM32CubeMX生成代码时没有勾选在根目录下生成: 取消勾选在根目…

8月3日星期日今日早报简报微语报早读

8月3日星期日,农历闰六月初十,早报#微语早读。1、广西防城港:奔驰女司机身份已查清,结果将统一对外发布;2、陈艺文、陈佳包揽游泳世锦赛女子跳水三米板金银牌;3、九省份保险业已赔付暴雨灾害损失5.2亿元&am…

wxPython 实践(六)对话框

wxPython 实践(一)概述 wxPython 实践(二)基础控件 wxPython 实践(三)页面布局 wxPython 实践(四)事件响应 wxPython 实践(五)高级控件 wxPython 实践&#x…

MATLAB科研数据可视化技术

互联网的飞速发展伴随着海量信息的产生,而海量信息的背后对应的则是海量数据。如何从这些海量数据中获取有价值的信息来供人们学习和工作使用,这就不得不用到大数据挖掘和分析技术。数据可视化分析作为大数据技术的核心一环,其重要性不言而喻…

文明存续的时间博弈:论地球资源枯竭临界期的技术突围与行动紧迫性

摘要当地球资源消耗以指数级速度逼近生态承载力极限,人类文明正面临“存续还是消亡”的终极抉择。本文基于地球资源枯竭的实证数据与技术突破的可行性分析,揭示文明存续的时间窗口已进入不可逆临界期(2040-2070年),论证…

Elasticsearch 8.19.0 和 9.1.0 中 LogsDB 和 TSDS 的性能与存储改进

作者:来自 Elastic Martijn Van Groningen 探索 TSDS 和 LogsDB 的最新增强功能,包括优化 I/O、提升合并性能等。 Elasticsearch 带来了许多新功能,帮助你为你的使用场景构建最佳搜索解决方案。通过我们的示例笔记本深入学习,开始…

cs336之注意pytorch的tensor在哪里?(assert的使用)

问题 记住:无论何时你在pytorch中有一个张量tensor,你应该始终问一个问题:它当前位于哪里? 注意它在CPU还是在GPU中。要判断它在哪里,可以使用python的assert断言语句。 assert断言 在 Python 中,assert 是…

Mysql 分区表

分区表是将一张表分成多张独立子表,每个子表是一个区,目的是提高查询效率。 从 server 层来看,只有一张表。但是从引擎层来看,是多张表,对应多个.idb文件。引擎层访问数据只访问特定分区表,也只对特定分区表…