leetcode43. 字符串相乘 經典大數+和*

43. 字符串相乘

難度中等264

給定兩個以字符串形式表示的非負整數?num1?和?num2,返回?num1?和?num2?的乘積,它們的乘積也表示為字符串形式。

示例 1:

輸入: num1 = "2", num2 = "3"
輸出: "6"

示例?2:

輸入: num1 = "123", num2 = "456"
輸出: "56088"

說明:

  1. num1?和?num2?的長度小于110。
  2. num1?和?num2?只包含數字?0-9
  3. num1?和?num2?均不以零開頭,除非是數字 0 本身。
  4. 不能使用任何標準庫的大數類型(比如 BigInteger)直接將輸入轉換為整數來處理
class Solution {/*** 計算形式*    num1*  x num2*  ------*  result*/// 計算結果String res = "0";public String multiply(String num1, String num2) {if (num1.equals("0") || num2.equals("0")) {return "0";}// num2 逐位與 num1 相乘for (int i = num2.length() - 1; i >= 0; i--) {int carry = 0;// 保存 num2 第i位數字與 num1 相乘的結果StringBuilder temp = new StringBuilder();// 補 0 for (int j = 0; j < num2.length() - 1 - i; j++) {temp.append(0);}int n2 = num2.charAt(i) - '0';// num2 的第 i 位數字 n2 與 num1 相乘for (int j = num1.length() - 1; j >= 0 || carry != 0; j--) {int n1 = j < 0 ? 0 : num1.charAt(j) - '0';int product = (n1 * n2 + carry) % 10;temp.append(product);carry = (n1 * n2 + carry) / 10;}// 將當前結果與新計算的結果求和作為新的結果res = addStrings(res, temp.reverse().toString());}return res;}/*** 對兩個字符串數字進行相加,返回字符串形式的和*/public String addStrings(String num1, String num2) {StringBuilder builder = new StringBuilder();int carry = 0;for (int i = num1.length() - 1, j = num2.length() - 1;i >= 0 || j >= 0 || carry != 0;i--, j--) {int x = i < 0 ? 0 : num1.charAt(i) - '0';int y = j < 0 ? 0 : num2.charAt(j) - '0';int sum = (x + y + carry) % 10;builder.append(sum);carry = (x + y + carry) / 10;}return builder.reverse().toString();}
}

?

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

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

相關文章

ffmpeg優化mp4以及hls參數設置

ffmpeg是開源的音頻視頻編解碼工具 然而默認的參數對MP4不友好,需要自己設置 這里記錄一下簡單的優化參數 優化MP4使moov atom位于文件開頭 moov atom是mp4的索引信息. 瀏覽器獲得moov atom后,可以隨機搜索文件位置,讓拖動自由 ffmpeg默認是將moov atom放在文件末尾,我們需要前…

游戲熱更新:游戲客戶端熱更新那點事

前言 熱更新的內容可以是美術資源,可以是代碼,但相對來說,美術資源的更新不會受到約束,代碼實際上是重災區。本文介紹的主要是客戶端代碼熱更新。 熱更新對于開發者來說是一件麻煩事,特別對于看重效率、便捷性和結構的程序員來說,熱更新就是運營人員的不懂技術的…

Unity客戶端開發優化要點

腳本方面1、不需要高頻率調用的函數&#xff0c;使用InvokeRepeating&#xff08;或Time.frameCount%n&#xff09;代替Update2、SetParent、Instantiate、Find、IO操作、SetActive、GetComponent等耗時較長的接口應在loading的時候做3、Update盡量減少代碼邏輯、減少臨時變量、…

leetcode214. 最短回文串

214. 最短回文串 難度困難114 給定一個字符串 s&#xff0c;你可以通過在字符串前面添加字符將其轉換為回文串。找到并返回可以用這種方式轉換的最短回文串。 示例 1: 輸入: "aacecaaa" 輸出: "aaacecaaa"示例 2: 輸入: "abcd" 輸出: "…

Java對象的序列化

對象序列化就是把一個對象變為二進制數據流的一種方法。 一個類要想被序列化&#xff0c;就行必須實現java.io.Serializable接口。雖然這個接口中沒有任何方法&#xff0c;就如同之前的cloneable接口一樣。實現了這個接口之后&#xff0c;就表示這個類具有被序列化的能力。 先…

游戲服務器架構:網絡服務器端程序線程劃分

服務器端高性能網絡編程的核心在于架構,而架構的核心在于進程-線程模型的選擇。 作為服務器需要做網絡數據的收發,需要做數據庫拉取和保存,需要做日志存儲,需要做常規的游戲邏輯處理.....在這里我把這些功能劃分為三個大的線程類型:IO線程,事件線程,第三方庫線程。 …

游戲中的常見概率設計分析

前言游戲中的概率真的是讓人又愛又恨&#xff0c;很多玩家因為自己的屌絲氣質&#xff08;白嫖&#xff09;而棄坑玩不下去的&#xff0c;比如人盡皆知的某陰陽師&#xff0c;除了氪金&#xff0c;還肝&#xff0c;而且如果你的臉真的非常的黑&#xff0c;那也是打不過那些0氪金…

一個通用游戲后臺的設計模式實踐總結

搞業務開發的時候&#xff0c;發現有一些代碼的開發會讓人感覺非常簡便舒服&#xff0c;有一些代碼的開發卻有時候會讓人感覺心智負擔比較大。逐步總結的過程中&#xff0c;發現讓開發人員寫起來感覺舒服的代碼&#xff0c;大概率是因為當前模塊與其他模塊代碼耦合度低&#xf…

leetcode103. 二叉樹的鋸齒形層次遍歷

給定一個二叉樹&#xff0c;返回其節點值的鋸齒形層次遍歷。&#xff08;即先從左往右&#xff0c;再從右往左進行下一層遍歷&#xff0c;以此類推&#xff0c;層與層之間交替進行&#xff09;。 例如&#xff1a; 給定二叉樹 [3,9,20,null,null,15,7], 3 / \ 9 20 …

大型游戲后臺實踐淺談

國家新聞出版署8月30日下發切實防止未成年人沉迷網絡游戲的通知,要求從今天(9月1日)起,所有網絡游戲企業僅可在周五、周六、周日和法定節假日每日20時至21時向未成年人提供1小時服務,其他時間均不得以任何形式向未成年人提供網絡游戲服務。通知發布后,各大游戲廠商火速回…

如何使用弱網環境來驗證游戲中的一些延遲問題

關于弱網 在當今移動互聯網盛行的時代,網絡的形態除了有線連接,還2G/3G/Edge/4G/Wifi等多種手機網絡連接方式。不同的協議、不同的制式、不同的速率,使移動應用運行的場景更加豐富。 從測試角度來說,需要額外關注的場景就遠不止斷網、網絡故障等情況了。對于弱網的數據定義…

使用nginx分片功能提升緩存效率,支持可拖拽式播放視頻

Nginx的slice模塊可以將一個請求分解成多個子請求,每個子請求返回響應內容的一個片段,讓大文件的緩存更有效率。 HTTP Range請求 HTTP客戶端下載文件時,如果發生了網絡中斷,必須重新向服務器發起HTTP請求,這時客戶端已經有了文件的一部分,只需要請求剩余的內容,而不需要…

Nginx 配置TCP和UDP負載均衡

前言 Nginx除了以前常用的HTTP負載均衡外,Nginx增加基于TCP協議實現的負載均衡方法。 HTTP負載均衡,也就是我們通常所有“七層負載均衡”,工作在第七層“應用層”。而TCP負載均衡,就是我們通常所說的“四層負載均衡”,工作在“網絡層”和“傳輸層”。例如,…

leetcode116. 填充每個節點的下一個右側節點指針

116. 填充每個節點的下一個右側節點指針 難度中等128 給定一個完美二叉樹&#xff0c;其所有葉子節點都在同一層&#xff0c;每個父節點都有兩個子節點。二叉樹定義如下&#xff1a; struct Node {int val;Node *left;Node *right;Node *next; } 填充它的每個 next 指針&am…

你的代碼是否按照高內聚、低耦合的原則來設計的?

我們一直強調軟件開發中要按照高內聚、低耦合的設計原則來做代碼結構設計。c語言和c++不同,c語言面向過程、c++面向對象。 真正的項目中,要對業務升級,原來的業務函數需要保留,要保證老的功能繼續維持,不能直接刪除,這時候c語言面向過程,通常使用回調的方法。c+…

leetcode117. 填充每個節點的下一個右側節點指針 II

給定一個二叉樹 struct Node { int val; Node *left; Node *right; Node *next; } 填充它的每個 next 指針&#xff0c;讓這個指針指向其下一個右側節點。如果找不到下一個右側節點&#xff0c;則將 next 指針設置為 NULL。 初始狀態下&#xff0c;所有 next 指針都被…

你擔心大家會濫用的全局變量,大家(包括你自己)一定會濫用

前言 不要使用全局變量的道理大家都懂,基本上在大家學習編程過程中很早就會被教育到,但是有時候我們也會禁不住誘惑用到一些似非實是的全局變量,只不過這些全局變量會穿上馬甲,讓你不會一下看穿它的巨大危害,濫用全局變量會引申帶來其它更為嚴重的結構性系統問題。…

Android Studio下載安裝教程及開發環境搭建

Android Stuio是本次Google io的一大亮點啊&#xff0c;一大早起來就趕緊下載來玩玩了。。。 如果你不幸被墻了&#xff0c;可以去這個帖子下載&#xff0c;我已經上傳到百度盤里面了。 [Android利器]Android Studio下載地址來啰 。。http://www.eoeandroid.com/thread-275380-…

leetcode124. 二叉樹中的最大路徑和

難度困難314 給定一個非空二叉樹&#xff0c;返回其最大路徑和。 本題中&#xff0c;路徑被定義為一條從樹中任意節點出發&#xff0c;達到任意節點的序列。該路徑至少包含一個節點&#xff0c;且不一定經過根節點。 示例 1: 輸入: [1,2,3]1/ \2 3輸出: 6示例 2: 輸入: …

深入剖析阻塞式socket的timeout

前言 網絡編程中超時時間是一個重要但又容易被忽略的問題,對其的設置需要仔細斟酌。 本文討論的是socket設置為阻塞模式,如果socket處于阻塞模式運行時,就需要考慮處理socket操作超時的問題。 所謂阻塞模式,是指其完成指定的操作之前阻塞當前的進程或線程,直到操作…