摘要:示例輸入輸出示例輸入輸出說明和的長(zhǎng)度小于。和均不以零開頭,除非是數(shù)字本身。舉例說明這兩個(gè)數(shù)的乘積的長(zhǎng)度一定不會(huì)超過,分別是字符串的長(zhǎng)度。第一輪第二輪至此該數(shù)組變?yōu)槿缓笤購奈膊刻幚磉M(jìn)位。
題目地址:
https://leetcode-cn.com/probl...
題目描述:
給定兩個(gè)以字符串形式表示的非負(fù)整數(shù) num1 和 num2,返回 num1 和 num2 的乘積,它們的乘積也表示為字符串形式。
示例 1:
輸入: num1 = "2", num2 = "3"
輸出: "6"
示例 2:
輸入: num1 = "123", num2 = "456"
輸出: "56088"
說明:
num1 和 num2 的長(zhǎng)度小于110。
num1 和 num2 只包含數(shù)字 0-9。
num1 和 num2 均不以零開頭,除非是數(shù)字 0 本身。
不能使用任何標(biāo)準(zhǔn)庫的大數(shù)類型(比如 BigInteger)或直接將輸入轉(zhuǎn)換為整數(shù)來處理。
解答:
如何使用計(jì)算機(jī)模仿大數(shù)想乘?
我們用手計(jì)算的時(shí)候,會(huì)邊乘邊計(jì)算進(jìn)位,并且把進(jìn)位加在前一位。
但是如果這里也這樣處理,那么會(huì)無比麻煩,實(shí)際上我們可以把每一位的乘積加上,然后
最后再統(tǒng)一處理。
舉例說明:
124 * 32
這兩個(gè)數(shù)的乘積的長(zhǎng)度一定不會(huì)超過m+n(m,n分別是字符串的長(zhǎng)度。)
我們開一個(gè)m+n長(zhǎng)度的數(shù)組val[m+n]。
第一輪:2*4 = 8,val[m+n-1] += 8,val[m+n-1] = 8
2*2 = 4,val[m+n-2] += 4,val[m+n-2] = 4 2*1 = 2,val[m+n-3] += 2,val[m+n-3] = 2
第二輪:3*4 = 12,val[m+n-2] += 12,val[m+n-2] = 16
3*2 = 6,val[m+n-3] += 6,val[m+n-3] = 8 3*1 = 3,val[m+n-4] += 3,val[m+n-4] = 3
至此,該數(shù)組變?yōu)?br>val[0,3,8,16,8]
然后再從尾部處理進(jìn)位。
比如最后一位8是沒有進(jìn)位的,往前處理,到了16,16 >= 10。
把該位變成16%10 = 6,并且獲得進(jìn)位16/10 = 1,再繼續(xù)向前處理
8要加上進(jìn)位變成9,然后再往前處理3不動(dòng)。
最后數(shù)組變成val[0,3,9,6,8]
到此,絕大部分工作已經(jīng)完成,只需要從左掃描數(shù)組找到第一個(gè)不為0的數(shù),然后把后面的加入字符串即可。
java ac代碼:
class Solution { public String multiply(String num1, String num2) { int[] val = new int[num1.length() + num2.length()]; for(int i = num1.length()-1,round = 0;i >= 0;i--,round++){ int k = val.length-1-round; for(int j = num2.length()-1;j >= 0;j--) { int temp = (num1.charAt(i)-"0")*(num2.charAt(j)-"0"); val[k--] += temp; } } int plus = 0; for(int i = val.length-1;i >= 0;i--) { int sum = val[i] + plus; val[i] = sum%10; plus = sum/10; } int loc = 0; String ans = ""; while(loc < val.length && val[loc] == 0)loc++; if(loc == val.length)ans = "0"; else for(int i = loc;i < val.length;i++) ans += val[i]; return ans; } }
更為詳細(xì)的講解可以參考這篇文章https://blog.csdn.net/afei__/...
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/73798.html
摘要:題目羅馬數(shù)字包含以下七種字符,,,,,和。字符數(shù)值例如,羅馬數(shù)字寫做,即為兩個(gè)并列的。通常情況下,羅馬數(shù)字中小的數(shù)字在大的數(shù)字的右邊。同樣地,數(shù)字表示為。給定一個(gè)羅馬數(shù)字,將其轉(zhuǎn)換成整數(shù)。 [TOC] 題目 羅馬數(shù)字包含以下七種字符: I, V, X, L,C,D 和 M。 字符 數(shù)值 I 1 V 5 X ...
摘要:圖因此可以成為樹,在所有可能的樹中,具有最小高度的樹被稱為最小高度樹。給出這樣的一個(gè)圖,寫出一個(gè)函數(shù)找到所有的最小高度樹并返回他們的根節(jié)點(diǎn)。因此使用一個(gè)數(shù)組代表每個(gè)節(jié)點(diǎn)的入度,若入度為就是葉子節(jié)點(diǎn)。 題目地址:https://leetcode-cn.com/probl...題目描述: 對(duì)于一個(gè)具有樹特征的無向圖,我們可選擇任何一個(gè)節(jié)點(diǎn)作為根。圖因此可以成為樹,在所有可能的樹中,具有最小...
摘要:關(guān)于遞歸這里提一兩點(diǎn)遞歸基本有這幾步遞歸的模板,終止條件,遞歸調(diào)用,邏輯處理。 ?作者簡(jiǎn)介:大家好,我是車神哥,府學(xué)路18號(hào)的車神? ?個(gè)人主頁:應(yīng)無所住而生...
摘要:對(duì)于每個(gè)氣球,提供的輸入是水平方向上,氣球直徑的開始和結(jié)束坐標(biāo)??梢陨涑龅墓臄?shù)量沒有限制。弓箭一旦被射出之后,可以無限地前進(jìn)。我們想找到使得所有氣球全部被引爆,所需的弓箭的最小數(shù)量。解答這是一道區(qū)間覆蓋問題,不太好說清楚,利用模板即可。 題目地址:https://leetcode-cn.com/probl...題目描述:在二維空間中有許多球形的氣球。對(duì)于每個(gè)氣球,提供的輸入是水平方...
閱讀 965·2021-11-17 09:33
閱讀 424·2019-08-30 11:16
閱讀 2479·2019-08-29 16:05
閱讀 3362·2019-08-29 15:28
閱讀 1402·2019-08-29 11:29
閱讀 1958·2019-08-26 13:51
閱讀 3396·2019-08-26 11:55
閱讀 1214·2019-08-26 11:31