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
  • 前言 本文介紹一款使用 C# 與 WPF 開發的音頻播放器,其界面簡潔大方,操作體驗流暢。該播放器支持多種音頻格式(如 MP4、WMA、OGG、FLAC 等),並具備標記、實時歌詞顯示等功能。 另外,還支持換膚及多語言(中英文)切換。核心音頻處理採用 FFmpeg 組件,獲得了廣泛認可,目前 Git ...
  • OAuth2.0授權驗證-gitee授權碼模式 本文主要介紹如何筆者自己是如何使用gitee提供的OAuth2.0協議完成授權驗證並登錄到自己的系統,完整模式如圖 1、創建應用 打開gitee個人中心->第三方應用->創建應用 創建應用後在我的應用界面,查看已創建應用的Client ID和Clien ...
  • 解決了這個問題:《winForm下,fastReport.net 從.net framework 升級到.net5遇到的錯誤“Operation is not supported on this platform.”》 本文內容轉載自:https://www.fcnsoft.com/Home/Sho ...
  • 國內文章 WPF 從裸 Win 32 的 WM_Pointer 消息獲取觸摸點繪製筆跡 https://www.cnblogs.com/lindexi/p/18390983 本文將告訴大家如何在 WPF 裡面,接收裸 Win 32 的 WM_Pointer 消息,從消息裡面獲取觸摸點信息,使用觸摸點 ...
  • 前言 給大家推薦一個專為新零售快消行業打造了一套高效的進銷存管理系統。 系統不僅具備強大的庫存管理功能,還集成了高性能的輕量級 POS 解決方案,確保頁面載入速度極快,提供良好的用戶體驗。 項目介紹 Dorisoy.POS 是一款基於 .NET 7 和 Angular 4 開發的新零售快消進銷存管理 ...
  • ABP CLI常用的代碼分享 一、確保環境配置正確 安裝.NET CLI: ABP CLI是基於.NET Core或.NET 5/6/7等更高版本構建的,因此首先需要在你的開發環境中安裝.NET CLI。這可以通過訪問Microsoft官網下載並安裝相應版本的.NET SDK來實現。 安裝ABP ...
  • 問題 問題是這樣的:第三方的webapi,需要先調用登陸介面獲取Cookie,訪問其它介面時攜帶Cookie信息。 但使用HttpClient類調用登陸介面,返回的Headers中沒有找到Cookie信息。 分析 首先,使用Postman測試該登陸介面,正常返回Cookie信息,說明是HttpCli ...
  • 國內文章 關於.NET在中國為什麼工資低的分析 https://www.cnblogs.com/thinkingmore/p/18406244 .NET在中國開發者的薪資偏低,主要因市場需求、技術棧選擇和企業文化等因素所致。歷史上,.NET曾因微軟的閉源策略發展受限,儘管後來推出了跨平臺的.NET ...
  • 在WPF開發應用中,動畫不僅可以引起用戶的註意與興趣,而且還使軟體更加便於使用。前面幾篇文章講解了畫筆(Brush),形狀(Shape),幾何圖形(Geometry),變換(Transform)等相關內容,今天繼續講解動畫相關內容和知識點,僅供學習分享使用,如有不足之處,還請指正。 ...
  • 什麼是委托? 委托可以說是把一個方法代入另一個方法執行,相當於指向函數的指針;事件就相當於保存委托的數組; 1.實例化委托的方式: 方式1:通過new創建實例: public delegate void ShowDelegate(); 或者 public delegate string ShowDe ...