算法競賽階段二-數據結構(38)數據結構動態鏈表list

動態鏈表(List)的基本概念

動態鏈表是一種線性數據結構,通過節點間的指針連接實現動態內存分配。與數組不同,鏈表的大小可隨需增減,插入和刪除操作的時間復雜度為 O(1)(已知位置時),但隨機訪問需要 O(n) 時間。

常見動態鏈表類型

  1. 單向鏈表
    每個節點包含數據和指向下一個節點的指針。

    class Node:def __init__(self, data):self.data = dataself.next = None
    

  2. 雙向鏈表
    節點包含指向前驅和后繼的指針,支持雙向遍歷。

    class Node:def __init__(self, data):self.data = dataself.prev = Noneself.next = None
    

  3. 循環鏈表
    尾節點指向頭節點,形成閉環。

動態鏈表的操作

插入節點
在頭部插入:

new_node = Node(data)
new_node.next = head
head = new_node

在中間插入(已知前驅節點 prev_node):

new_node.next = prev_node.next
prev_node.next = new_node

刪除節點
刪除頭節點:

head = head.next

刪除中間節點(已知前驅節點 prev_node):

prev_node.next = prev_node.next.next

動態鏈表的優缺點

優點

  • 內存按需分配,避免靜態數組的浪費。
  • 插入/刪除高效,無需移動其他元素。

缺點

  • 隨機訪問效率低。
  • 需要額外空間存儲指針。

動態鏈表的應用場景

  • 實現棧、隊列等抽象數據類型。
  • 內存管理中的動態分配(如操作系統的空閑內存塊管理)。
  • 需要頻繁插入/刪除的場景(如實時系統)。

示例:單向鏈表的完整實現

class LinkedList:def __init__(self):self.head = Nonedef append(self, data):new_node = Node(data)if not self.head:self.head = new_nodereturnlast = self.headwhile last.next:last = last.nextlast.next = new_nodedef print_list(self):current = self.headwhile current:print(current.data, end=" -> ")current = current.nextprint("None")

注意事項

  • 動態鏈表需手動管理內存(如 C/C++ 中需釋放節點)。
  • 在 Python/Java 等語言中,垃圾回收機制自動處理內存釋放。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/web/91304.shtml
繁體地址,請注明出處:http://hk.pswp.cn/web/91304.shtml
英文地址,請注明出處:http://en.pswp.cn/web/91304.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

Qt 移動應用推送通知實現

推送通知是移動應用提升用戶粘性的核心功能——無論是即時消息提醒、活動推送還是狀態更新,都需要通過推送功能觸達用戶。Qt雖未直接提供跨平臺推送API,但可通過集成原生服務(如Firebase Cloud Messaging、Apple Push Notification service&a…

Word和WPS文字如何制作分欄試卷?想分幾欄分幾欄

使用Word和WPS文字制作試卷的時候,通常會使用A3大小的紙張,橫向布局。但是如果題目的題干、問題、選項文字太少,會帶來試卷上有較大的空白,既不美觀又浪費紙,解決辦法就是將試卷分欄,根據需要分成多欄&…

ubuntu 安裝vmware tools

VMware Workstation菜單欄->虛擬機->安裝VMware Tools 打開ubuntu內加載的光盤,復制VMwareTools-10.3.26-22085142.tar.gz,解壓出來 sudo ./vmware-install.pl #執行安裝軟件 VMware Tools 安裝完成以后重啟Ubuntu,重啟以后就可以直…

【實時Linux實戰系列】在實時應用中進行負載均衡

在實時應用中,負載均衡是確保系統能夠高效處理多個任務的關鍵技術。通過合理調度任務到不同的處理單元,負載均衡可以提高系統的整體性能,減少延遲,并提高資源利用率。在實時 Linux 系統中,負載均衡尤為重要&#xff0c…

bash的特性-命令和文件自動補全

一、前言在 Linux Shell 編程和日常使用中,Bash 的自動補全功能 是一個非常強大且實用的特性。它不僅可以節省輸入時間,還能有效減少拼寫錯誤,提升命令執行效率。本文將帶你全面了解 Bash 的自動補全機制,包括:? 命令…

Ubuntu系統 系統盤和數據盤擴容具體操作

Linux磁盤配置和需求,以下是完整的操作方案: 可以看到系統盤vda3 還有48GB 數據盤則是還有512GB沒有掛載使用,下面是完成數據擴容的具體操作 一、完成系統盤擴容(使用98GB空間) # 1. 擴展邏輯卷(LVM架構&am…

從0到1學Pandas(七):Pandas 在機器學習中的應用

目錄一、數據預處理1.1 特征提取1.2 數據標準化與歸一化1.3 特征編碼二、特征工程2.1 特征選擇?2.2 特征組合與衍生?2.3 缺失值處理策略?三、模型訓練與評估3.1 數據集劃分3.2 模型訓練與預測3.3 模型評估與調優四、Pipeline 構建4.1 自動化工作流4.2 模型部署與應用4.3 模型…

LangChain和LangGraph 里面的 `create_react_agent`有什么不同

這兩個函數雖然名稱相同,但來自不同的庫(LangChain 和 LangGraph),它們在實現和使用上有一些關鍵區別: 主要區別特性LangChain 的 create_react_agentLangGraph 的 create_react_agent所屬庫LangChainLangGraph設計目的…

PostgreSQL 與 Oracle 數據庫字段類型的詳細對比

一、數值類型對比數據類型OraclePostgreSQL說明整數NUMBER(p,0)SMALLINT/INT/BIGINTOracle 統一用 NUMBER,PG 區分精度范圍浮點數BINARY_FLOATREAL單精度浮點雙精度浮點BINARY_DOUBLEDOUBLE PRECISION雙精度浮點高精度小數NUMBER(p,s)NUMERIC(p,s)精確數值存儲自增序…

JVM 性能調優實戰:讓系統性能 “飛” 起來的核心策略

在 Java 應用的生命周期中,性能問題如同隱藏的 “暗礁”—— 初期可能不顯眼,但隨著用戶量增長和業務復雜度提升,微小的性能損耗會被無限放大,最終導致系統響應遲緩、頻繁卡頓甚至崩潰。JVM 性能調優的目標,就是通過優…

Android Handler 完全指南

在 Android 開發中,Handler 是線程通信的核心工具 —— 當你在子線程下載圖片后需要更新 UI,當你在 TCP 連接中收到數據需要通知界面,當你需要延遲執行某個任務時,都會用到 Handler。這個看似簡單的類,卻蘊含著 Androi…

梳理Ego-Planner模式下5通道、6通道與無人機模式的關系

Copilot said: 你需要梳理Ego-Planner模式下5通道、6通道與無人機模式的關系,以及軌跡跟隨、緊急情況和人工接管的流程。下面結合你的描述和三張圖片,對核心邏輯進行總結和整理: --- ## 一、狀態組合與對應模式(見圖1)…

odbc和jdbc什么區別

ODBC 和 JDBC 都是用于連接和操作數據庫的標準接口,但它們分別面向不同的編程語言和平臺。下面是它們的區別與對比,幫助你理解它們的用途和適用場景。📊 一、基本概念對比特性ODBC(Open Database Connectivity)JDBC&am…

境外期貨Level2高頻Tick歷史行情數據獲取與應用指南

在金融量化分析中,本地數據的高效使用是提升策略效果的重要基礎。本文以CSV格式的本地數據為核心,以外盤期貨分鐘數據、CME/COMEX/CBOT歷史行情為例,闡述專業化的數據處理與應用方法,為研究者提供可行性方案。一、數據預處理標準化…

迅為RK3588開發板安卓GPIO調用-APP運行測試

將網盤上的安卓工程文件復制到 Windows 電腦上。確保工程路徑中使用英文字符,不包含中文。接著,啟動 Android Studio,點擊“Open”按鈕選擇應用工程文件夾,然后點擊“OK”。由于下載 Gradle 和各種 Jar 包可能需要一段時間&#x…

以太坊下一階段的關鍵——隱私

1. 引言 隨著以太坊慶祝其十周年紀念,Aztec Labs 聯合創始人兼 CEO Zac Williamson 和以太坊基金會 PSE 負責人 Sam Richards 表示,以太坊必須加強其對隱私的原始承諾。 以太坊慶祝十周年紀念,標志著智能合約、去中心化金融(DeF…

CTFpwn學習筆記1-棧溢出

棧溢出通過寫入超出數組定義范圍的字符長度達到溢出,從而覆蓋棧上其余數據,覆蓋返回地址約等于控制程序執行流例如:經過ida反編譯后,發現這里要將v2的值修改為11.28125才能獲得flag,同時我們可以發現這里使用了gets這個…

使用 Android Studio 中的 Gemini,讓 Flutter 開發更便捷

作者 / Flutter 產品經理 Ander Dobo 及 Gemini in Android Studio 產品經理 Sandhya Mohan在 Android Studio 中創建 Android 應用的 Flutter 開發者將迎來一次重大的飛躍: Android Studio 中的 Gemini 已全面支持 Dart 和 Flutter 開發!這意味著您可以直接在您青睞…

Deep Learning_ Foundations and Concepts-Springer (2024)【拜讀】前向編碼器20章

Diffusion Models 擴散模型 我們已經了解到,構建強大的生成模型的一種有效方法是:先引入一個關于潛在變量z的分布p(z),然后使用深度神經網絡將z變換到數據空間x。由于神經網絡具有通用性,能夠將簡單固定的分布轉化為關于x的高度靈…

Spring全局異常處理最佳實踐

全局異常處理器詳解 什么是全局異常處理器? 全局異常處理器是Spring框架提供的統一異常處理機制,用于集中處理應用程序中所有控制器(Controller)層拋出的異常。它的核心價值在于: 統一異常處理:避免在每個C…