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
英文地址,請注明出處:http://en.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文件。引擎層訪問數據只訪問特定分區表,也只對特定分區表…