兩數相加

来源:https://www.cnblogs.com/whtmomo/archive/2023/08/21/17647078.html
-Advertisement-
Play Games

## 題目描述 給你兩個 非空 的鏈表,表示兩個非負的整數。它們每位數字都是按照 逆序 的方式存儲的,並且每個節點只能存儲 一位 數字。請你將兩個數相加,並以相同形式返回一個表示和的鏈表。你可以假設除了數字 0 之外,這兩個數都不會以 0 開頭。 ## 例子 > 輸入:l1 = [2,4,3], l ...


題目描述

給你兩個 非空 的鏈表,表示兩個非負的整數。它們每位數字都是按照 逆序 的方式存儲的,並且每個節點只能存儲 一位 數字。請你將兩個數相加,並以相同形式返回一個表示和的鏈表。你可以假設除了數字 0 之外,這兩個數都不會以 0 開頭。

例子

輸入:l1 = [2,4,3], l2 = [5,6,4]
輸出:[7,0,8]
解釋:342 + 465 = 807.

輸入:l1 = [0], l2 = [0]
輸出:[0]

輸入:l1 = [9,9,9,9,9,9,9], l2 = [9,9,9,9]
輸出:[8,9,9,9,0,0,0,1]

題解:

按照題意,類比小學數學的兩位數加法,只需要將同位次的數字和“進位”相加,就能得到最後結果。
設A數組為 A[m] = { $a_0 , a_1 , a_2 , \dots , a_{m-1} $ }, 相似地,B數組為B[n] = {$b_0 , b_1 , b_2 , \dots , b_{n-1} $}。

要得到C = A + B , 只需要 $$ c_i = a_i + b_i + t \qquad ,其中t為進位 $$

/**
 * Definition for singly-linked list.
 * struct ListNode {
 *     int val;
 *     ListNode *next;
 *     ListNode() : val(0), next(nullptr) {}
 *     ListNode(int x) : val(x), next(nullptr) {}
 *     ListNode(int x, ListNode *next) : val(x), next(next) {}
 * };
 */
class Solution {
public:
    ListNode* addTwoNumbers(ListNode* l1, ListNode* l2) {
        ListNode *res = new ListNode();
        ListNode *temp = res;
        int t = 0;
        while ( l1 || l2) {		// l1和l2不一樣長,需要等到兩個數組都計算完畢才結束迴圈
            if ( l1 ) {
                t += l1->val;		// t臨時變數加上l1數組當前位次的值
                l1 = l1->next;		// l1 指向下一位,準備下一個數字的計算
            }
            if ( l2) {
                t += l2->val;		// 同上
                l2 = l2->next;		// 同上
            }

            ListNode *newNode = new ListNode(t % 10);	//調用構造函數
            temp->next = newNode;
            temp = temp->next;	// temp指針指向新節點,保證temp指針指向的是末尾節點
            t /= 10;	// 這裡的t 為 進位 ,比如說 l1->val + l2->val = 13 ,那麼插入的節點值為 13 % 10 == 3
            			//而進位為 13 / 10 == 1
        }
        //當計算完畢後,有可能還存在進位,所以判斷t的值,如果不為0,就需要再插入到末尾節點。
        if ( t > 0) {
            ListNode *newNode = new ListNode(1);
            temp->next = newNode;
        }
		//由於res是帶頭節點的單鏈表,要使得第一個節點就為元素,則返回下一個節點。
        return res->next;
    }
};

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • ##### 8 JavaScript函數 在JS中聲明函數和python差不多. 也要有一個關鍵字頂在前面. python是`def`, 到了JS里換成了`function`, 只不過在JS中沒有像python那麼死板, 必須`def`後面必須跟上函數名. 這也為我們未來做逆向提供了第一個超大的伏筆 ...
  • 在當今快節奏的社會中,技術變化日新月異。作為一名技術博客站長,我深切感受到了學習和傳播知識的重要性。為了更好地滿足讀者的需求,我決定採用VuePress搭建一個功能強大且易於維護的知識庫平臺,名為LearnData。本文將介紹我如何利用VuePress構建LearnData,並展示一些相關的代碼示例... ...
  • ## 直連 直連模式下,選擇一個玩家充當伺服器(房主)。如果游戲出現不同步,那麼均按房主的世界來,玩家1可以作弊修改其游戲來影響其他玩家的世界 針對兩個玩家來說,直連連接質量更好,延遲小 如果玩家數量很多,不同玩家間的通信則需要靠房主為中介,那通信質量與房主主機配置、網路情況有很大關係 ## 專用服 ...
  • 從研發的角度來看如果系統上下文清晰、應用架構設計簡單、應用拆分合理應該稱之為架構合理。基於以上的定義可以從以下三個方面來梳理評估: ...
  • ### 歡迎訪問我的GitHub > 這裡分類和彙總了欣宸的全部原創(含配套源碼):[https://github.com/zq2599/blog_demos](https://github.com/zq2599/blog_demos) ### 本篇概覽 - 前文[《Docker下elasticse ...
  • ## 面向對象三要素 封裝:顧名思義,將函數或變數集中定義在類中,而非散亂分佈。 繼承:擴展類的功能。 多態:在擴展類的功能的基礎之上,實現其內部方法的多樣性。 ### 多態的本質 針對某個類型的方法調用,其真正執行的方法取決於運行時期實際類型的方法。 ```java package Project ...
  • 之前用的python2.7+robotframework進行的自動化測試,python3的還沒嘗試,今天嘗試了下,搭建環境的時候也是各種報錯,搞了幾小時才搞好了。 一、python安裝 下載python然後安裝,地址:https://www.python.org/,安裝時勾選添加到環境變數,安裝後c ...
  • ## 一、前言 - 還在為排查Java程式線上問題頭痛嗎,看我們用阿裡開源的診斷神器 Arthas 來幫您 - 本文開篇主要介紹 阿裡開源的診斷神器Arthas 3.7.0版本,watch、jad、classloader 命令,以 Debian 11、openjdk 11 為例 ## 二、Artha ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...