No.002:Add Two Numbers

来源:http://www.cnblogs.com/jing-an-feng-shao/archive/2016/09/22/5897917.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 sin ...


問題:

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.
Example:
Input: (2 -> 4 -> 3) + (5 -> 6 -> 4)
Output: 7 -> 0 -> 8

官方難度:

Medium

翻譯:

現有2個鏈表結構,存儲非0的數字,每個節點的數字都是個位數的而且倒著排序,把這2個鏈表的數字相加並倒序輸出。

例子:

鏈表一:2->4->3

鏈表二:5->6->4

輸出:7->0->8

思路:

1.Java中的鏈表結構,就是LinkedList。

2.Java中的集合迭代器ListIterator,擁有自末尾向前遍歷的特性,在這裡可以運用。

解題中可能遇到的困難:

1.創建ListIterator的時候,指針的位置需要指向鏈表的末尾。

解題代碼:

 1     private static List<Integer> method(List<Integer> list1, List<Integer> list2) {
 2         int sum1 = 0;
 3         int sum2 = 0;
 4         int size1 = list1.size();
 5         int size2 = list2.size();
 6         // 聲明2個ListIterator,可以逆向迭代,指針位置先給到最後一位
 7         ListIterator<Integer> iter1 = list1.listIterator(size1);
 8         ListIterator<Integer> iter2 = list2.listIterator(size2);
 9         // 逆序遍歷+累加
10         while (iter1.hasPrevious()) {
11             sum1 += iter1.previous() * Math.pow(10, --size1);
12         }
13         while (iter2.hasPrevious()) {
14             sum2 += iter2.previous() * Math.pow(10, --size2);
15         }
16         int sum = sum1 + sum2;
17         List<Integer> resultList = new LinkedList<>();
18         while (sum > 0) {
19             // 取末尾
20             resultList.add(sum % 10);
21             // 去末尾
22             sum /= 10;
23         }
24         return resultList;
25     }
View Code

測試代碼地址:

https://github.com/Gerrard-Feng/LeetCode/blob/master/LeetCode/src/com/gerrard/algorithm/medium/Q002.java

LeetCode題目地址:

https://leetcode.com/problems/add-two-numbers/

PS:如有不正確或提高效率的方法,歡迎留言,謝謝!


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

-Advertisement-
Play Games
更多相關文章
  • 1:頁面前端中對單個值進行轉碼 url: "ExtjsDemo.aspx?userName=" + encodeURI(userName) + "&passWord=" + encodeURI(pwd) + "" ...
  • 所有類型都繼承自System.Object System.Object的基本方法 | 名稱 | 訪問級別|說明 | | | | | |Equals()|public|如果兩個對象有相同的值就返回true| |GetHashCode()|public|返回對象的值的哈希碼 |ToString()|pu ...
  • http://skeletoncoder.blogspot.com/2006/10/jdbc-tutorials-commit-or-rollback.html JDBC Tutorials: Commit or Rollback transaction in finally block In mo ...
  • 1.Python 函數 函數是組織好的,可重覆使用的,用來實現單一,或相關聯功能的代碼段。 函數能提高應用的模塊性,和代碼的重覆利用率。你已經知道Python提供了許多內建函數,比如print()。但你也可以自己創建函數,這被叫做用戶自定義函數。 定義一個函數 你可以定義一個由自己想要功能的函數,以 ...
  • 註意,這個結構體,要是想在函數之間傳來傳去的話,必須要使用指針。。。。。。。 這個結構體里沒有 指針,這個類型可以說沒有“引用特性”。 被坑了一晚上。特此記錄。 ...
  • 1. 定義:匿名函數(Anonymous functions),也叫閉包函數(closures),允許 臨時創建一個沒有指定名稱的函數。最經常用作回調函數(callback)參數的值。當然,也有其它應用的情況。 2. 用法: 1)作為變數的值: 閉包函數也可以作為變數的值來使用。PHP 會自動把此種 ...
  • 1、線程安全 線程安全就是說多線程訪問同一代碼,不會產生不確定的結果。 2、List類和Set類List類和Set類是Collection集合介面的子介面。Set子介面:無序,不允許重覆。List子介面:有序,可以有重覆元素。 Set和List對比: Set:檢索元素效率低下,刪除和插入效率高,插入 ...
  • 題目: Given a string, find the length of the longest substring without repeating characters.Example:Given "abcabcbb", the answer is "abc", which the len ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...