2. Add Two Numbers

来源:http://www.cnblogs.com/boluo007/archive/2016/05/24/5524935.html
-Advertisement-
Play Games

You are given two linked lists representing two non-negative numbers. The digits are stored in reverse order and each of their nodes contain a single ...


You are given two linked lists representing two non-negative numbers. The digits are stored in reverse order and each of their nodes contain a single digit. Add the two numbers and return it as a linked list.

Input: (2 -> 4 -> 3) + (5 -> 6 -> 4)
Output: 7 -> 0 -> 8

 

 1 /**
 2  * Definition for singly-linked list.
 3  * struct ListNode {
 4  *     int val;
 5  *     struct ListNode *next;
 6  * };
 7  */
 8 struct ListNode* addTwoNumbers(struct ListNode* l1, struct ListNode* l2) {
 9     struct ListNode *phead;
10     struct ListNode *cur1;
11     struct ListNode *cur2;
12     struct ListNode *curp;
13     struct ListNode *dele;
14     struct ListNode *pnew;
15     phead = NULL;
16     cur1 = l1;
17     cur2 = l2;
18     int flag = 0;
19     while(cur1 != NULL || cur2 != NULL)
20     {
21          if(phead == NULL)
22          {
23              curp = (struct ListNode *)malloc(sizeof(struct ListNode));
24              memset(curp,0,sizeof(struct ListNode));
25              phead = curp;
26          }
27          else
28          {
29              pnew = (struct ListNode *)malloc(sizeof(struct ListNode));
30              memset(pnew,0,sizeof(struct ListNode));
31              curp->next = pnew;
32              curp = pnew;
33          }
34         if(cur1 == NULL)
35         {
36             curp->val = (cur2->val + flag) % 10;
37             flag = (cur2->val + flag) / 10;
38             dele = cur2;
39             cur2 = cur2->next;
40             free(dele);
41             dele = NULL;
42         }
43         else if(cur2 == NULL)
44         {
45             curp->val = (cur1->val + flag) % 10;
46             flag = (cur1->val + flag) / 10;
47             dele = cur1;
48             cur1 = cur1->next;
49             free(dele);
50             dele = NULL;
51         }
52         else
53          {
54             curp->val = (cur1->val + flag + cur2->val) % 10;
55             flag = (cur1->val + flag + cur2->val) /10;
56             dele = cur2;
57             cur2 = cur2->next;
58             free(dele);
59             dele = NULL;
60             dele = cur1;
61             cur1 = cur1->next;
62             free(dele);
63             dele = NULL;
64          }
65          
66     }
67     if(flag == 1)                            //最後要註意進位的問題!!!
68     {
69         pnew = (struct ListNode *)malloc(sizeof(struct ListNode));
70         memset(pnew,0,sizeof(struct ListNode));
71         curp->next = pnew;
72         pnew->val = 1;
73         return phead;
74     }
75     return phead;
76 }

 


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

-Advertisement-
Play Games
更多相關文章
  • 繼承 指的是一個類(稱為子類、子介面)繼承另外的一個類(稱為父類、父介面)的功能,並可以增加它自己的新功能的能力,繼承是類與類或者介面與介面之間最常見的關係;在Java中此類關係通過關鍵字extends明確標識,在設計時一般沒有爭議性; 實現 指的是一個class類實現interface介面(可以是 ...
  • 摘要:Python語言的特點 >優雅、明確、簡單 一、Python適合的領域 web網站和各種網路服務 系統工具和腳本 作為“膠水”語言,把其他語言開發的模塊包裝起來方便使用 二、Python不適合的領域 貼近硬體的代碼(首選C) 移動開發:ios/Android有各自的開發語言(Objc,Swif ...
  • 主要介紹spring mvc控制框架的流程及原理 Spring Web MVC處理請求的流程 具體執行步驟如下: 首先用戶發送請求————>前端控制器,前端控制器根據請求信息(如URL)來決定選擇哪一個頁面控制器進行處理並把請求委托給它,即以前的控制器的控制邏輯部分;圖2-1中的1、2步驟; 頁面控 ...
  • Appreciation to our TA, 王毅峰, who designed this task. 問題描述 JSON, JavaScript Object Notation,is an flexible format that uses human readable text to tran ...
  • 學習完如何寫'hello world'之後,我們還是不太滿意,因為這樣代碼就寫死了,以後運行的時候都只列印一局固定的話而已。 但是,我想在程式運行後,自己手動輸入內容怎麼辦,此時就要學習如何使用用戶交互了。 在python2.x中,用戶交互使用的是 raw_input("提示內容") 方法,例如 之 ...
  • 環境為centos 7,已經安裝了jdk7, jdk必須要安裝7及以上版本 1. 切換到非root用戶(目前的es不能使用root用戶) 1. 下載es並解壓: wget https://download.elasticsearch.org/elasticsearch/release/org/ela ...
  • 之前的路由模式是通過key相等來匹配 而通配符,顧名思義,符合條件,則進行消息匹配發送 將路由鍵和某模式進行匹配。此時隊列需要綁定要一個模式上。 符號“#”匹配一個或多個詞,符號“*”匹配不多不少一個詞。 因此“audit.#”能夠匹配到“audit.irs.corporate”,但是“audit. ...
  • 路由模式其實和訂閱模式差不多,只不過交換機的類型不同而已 路由模式可以用下圖來表示,比訂閱模式多了一個key,舉個慄子就是根據不同的人群來訂閱公眾號,來收取消息 根據不同的key來獲取不同的消息 最簡單的就是男性用戶以及女性用戶的關註信息是不同的,推送的內容當然也是根據不同分類來推送 下圖就是微信公 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...