鏈表題解——兩數相加【LeetCode】

方法一:遞歸

寫法一:創建新節點

算法思路解析

該實現采用 遞歸方式 逐位處理兩個鏈表,并考慮進位 carry

? 步驟拆解
  1. 遞歸終止條件:當 l1, l2 都為空且沒有進位(carry == 0),說明加法結束,返回 None

  2. 當前位求和:s = carry + l1.val (如果有) + l2.val (如果有)

  3. 計算當前節點的值與進位:當前節點值為 s % 10,進位為 s // 10

  4. 遞歸構造下一節點:遞歸調用 addTwoNumbers(l1.next, l2.next, carry) 處理下一位

  5. 創建當前節點并連接:使用 ListNode(s % 10, next_node) 構造當前節點并返回

class Solution:# l1 和 l2 為當前遍歷的節點,carry 為進位def addTwoNumbers(self, l1: Optional[ListNode], l2: Optional[ListNode], carry=0) -> Optional[ListNode]:if l1 is None and l2 is None and carry == 0:  # 遞歸邊界return Nones = carryif l1:s += l1.val  # 累加進位與節點值l1 = l1.nextif l2:s += l2.vall2 = l2.next# s 除以 10 的余數為當前節點值,商為進位return ListNode(s % 10, self.addTwoNumbers(l1, l2, s // 10))

時間與空間復雜度分析

時間復雜度:O(max(m, n))
  • 每次遞歸處理一個節點,最多遞歸 max(m, n) 層(m 和 n 為兩個鏈表的長度)。

空間復雜度:
類型復雜度說明
遞歸棧空間O(max(m, n))每層遞歸入棧一次
結果鏈表空間O(max(m, n) + 1)存儲最終和(可能有一個額外的進位位)

?? 注意:這是遞歸寫法,存在函數棧空間占用,若鏈表極長(如上千位),可能導致棧溢出風險(可改為迭代方式避免)。

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

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

相關文章

AutoGen框架的ReAct推理模式的多跳測試

問題:特斯拉公司 CEO 的出生地是哪個國家? 答案:南非。 推理過程: 第一跳:確定特斯拉(Tesla, Inc.)的 CEO。特斯拉的 CEO 是埃隆馬斯克(Elon Musk)。 第二跳:…

MCP-安全(entra)

保護 AI 工作流程:模型上下文協議服務器的 Entra ID 身份驗證 介紹 保護模型上下文協議 (MCP) 服務器的安全與鎖好家門一樣重要。保持 MCP 服務器開放會導致您的工具和數據遭受未經授權的訪問,從而導致安全漏洞。Microsoft Entra ID 提供強大的基于云的身…

Node.js特訓專欄-實戰進階:8. Express RESTful API設計規范與實現

?? 歡迎來到 Node.js 實戰專欄!在這里,每一行代碼都是解鎖高性能應用的鑰匙,讓我們一起開啟 Node.js 的奇妙開發之旅! Node.js 特訓專欄主頁 專欄內容規劃詳情 Express RESTful API設計規范與實現:構建標準化、可維護的接口服務 在前后端分離架構盛行的今天,RESTful A…

2025企業數字化轉型之道

進入2025年,企業的數字化轉型已經不再是選擇題,而是生存和發展的關鍵。如何抓住技術的浪潮,提高效率、提升客戶體驗、加強創新,成了企業亟需解決的問題。 1.自動化:釋放人力潛力 自動化是數字化轉型的起點。通過RPA&a…

TCP 保活定時器詳解:原理、配置與最佳實踐

一、TCP 保活定時器基礎原理 TCP 保活定時器(TCP Keepalive Timer)是 TCP 協議中用于檢測長時間無數據傳輸的連接是否仍然有效的機制。它通過在連接空閑一段時間后發送探測報文,確認對方主機是否仍然可達,從而避免在對端異常斷開…

瀏覽器工作原理27 [#]PWA:解決了web應用哪些問題

引用 《瀏覽器工作原理與實踐》 PWA,全稱是 Progressive Web App ,翻譯過來就是漸進式網頁應用。根據字面意思,它就是“漸進式 Web 應用”。對于 Web 應用很好理解了,就是目前普通的 Web 頁面,所以 PWA 所支持的首先是…

Leetcode百題斬-圖論

再開下一個坑,圖論專題居然以前都刷過了,三道Medium也沒什么好說的,直接過 994. Rotting Oranges[Medium] 發現一個很神奇的事,這一題我再5年前的時候做,還是個Easy,現在已經漲到Medium了。看來隨著通貨膨…

將Python Tkinter程序轉換為手機可運行的Web應用 - 詳細教程

前言 作為一名Python開發者,你可能已經使用Tkinter創建了一些桌面GUI應用。但是如何讓這些應用也能在手機上運行呢?本教程將詳細介紹如何將基于Tkinter的Python程序轉換為手機可訪問的Web應用,讓你的應用隨時隨地可用! 一、為什…

Markdown批量轉PDF工具:高效便捷的文檔轉換解決方案

Markdown批量轉PDF工具:高效便捷的文檔轉換解決方案 前言 在日常工作和學習中,我們經常需要將Markdown文檔轉換為PDF格式,無論是為了分享、打印還是歸檔。雖然有很多在線工具可以實現這一功能,但當面對大量文檔時,逐…

51c~嵌入式~PLC~歐姆龍~合集1

我自己的原文哦~ https://blog.51cto.com/whaosoft/14017854 > PLC-- 歐姆龍 --專輯 一、歐姆龍PLC指令應用 歐姆龍PLC是一種功能完善的緊湊型PLC,能為業界領先的輸送分散控制等提供高附加值機器控制;它還具有通過各種高級內裝板進行升級的能…

機器人 URDF學習筆記

目錄 URDF(Unified Robot Description Format) ? URDF 描述的內容包括: URDF(Unified Robot Description Format) 意思是:統一機器人描述格式。 它是一種用 XML 編寫的格式,專門用于描述機器…

MySQL-主從復制分庫分表

5 MySQL-主從復制&分庫分表 5.1mysql 主從復制 5.1.1. 概述 主從復制是將主數據庫的DDL和DML操作通過二進制日志(binlog文件)傳送到從庫服務器,然后在從庫上對這些日志重新執行,從而使得主庫和從庫的數據保持同步。 MySQL…

7.6.平衡二叉樹(英文縮寫為AVL樹)

一.平衡二叉樹的定義: 1.平衡二叉樹簡稱平衡樹(AVL樹,該縮寫來源于平衡二叉樹的發明人的名字簡稱); 2.結點的平衡因子左子樹高-右子樹高; 3.以上述圖片左下角的二叉樹為例,結點50的左子樹的高度為2,右子樹…

OpenCV CUDA模塊設備層-----將指向共享內存(shared memory)的指針封裝成一個 tuple函數smem_tuple()

操作系統:ubuntu22.04 OpenCV版本:OpenCV4.9 IDE:Visual Studio Code 編程語言:C11 算法描述 OpenCV的cv::cudev模塊中的一個用于 CUDA 編程的輔助函數,用于將指向共享內存(shared memory)的指針封裝成一…

paddlepaddle在RTX40系安裝注意事項

1 安裝簡介 1.1 安裝注意事項 顯卡型號:RTX4090 驅動版本:550.54.14 宿主機cuda版本:12.4 安裝方式:conda 注意cuda和cudnn的搭配 最初安裝是為了使用PaddleOCR,根據官網提示需要安裝cuda和cudnn。這里最關鍵的就是針…

車載以太網-組播

目錄 車載以太網中的組播:從原理到車載應用**一、組播的核心概念與車載網絡價值****二、車載以太網組播的關鍵協議與機制**1. **組播IP地址管理(IGMP協議)**2. **組播數據鏈路層實現(MAC地址映射)****三、車載以太網組播的典型應用場景**1. **自動駕駛與傳感器數據分發**2…

【雅思播客013】what do you do

【dialog】 A: Oh, look, there’s Veronica and her boyfriend.She’s always going on about him at the of?ce. Oh, great, they saw us. They’re coming this way. B: Oh, man... C: Jessica! Arthur! Hi! I’d like you to meet my boyfriend Greg, he’s the VP. of q…

Freebsd 14.2系統下 wifi網卡硬件驅動軟件配置調試大全

Freebsd 14.2系統下,網卡是AX200 先檢查網卡sysctl net.wlan.devices sysctl net.wlan.devices 能識別出已經安裝的 sysctl net.wlan.devices net.wlan.devices: iwlwifi0配置wlan0 # ifconfig wlan0 create wlandev iwlwifi0 # ifconfig wlan0 up # ifconfig …

Python打卡:Day39

知識點回顧 圖像數據的格式:灰度和彩色數據模型的定義顯存占用的4種地方 模型參數梯度參數優化器參數數據批量所占顯存神經元輸出中間狀態 batchisize和訓練的關系 浙大疏錦行

使用 GcExcel .NET 將 Excel 導出為 PDF

引言 在企業級應用開發中,經常需要將Excel數據導出為PDF格式以便于共享和打印。GrapeCity Documents for Excel(簡稱GcExcel)作為一款高性能的.NET Excel組件,提供了強大的PDF導出功能。本文將詳細介紹如何使用GcExcel .NET實現E…