43. Multiply Strings

Description

Given two non-negative integers num1 and num2 represented as strings, return the product of num1 and num2.

Note:

The length of both num1 and num2 is < 110.
Both num1 and num2 contains only digits 0-9.
Both num1 and num2 does not contain any leading zero.
You must not use any built-in BigInteger library or convert the inputs to integer directly.

Solution

找規(guī)律

這道題目也蠻有意思的吮廉。仔細想來,乘法是怎么做的呢汹族?

其實對兩個數(shù)做乘法,實際上就是將兩個數(shù)的位置兩兩組合做乘法,然后求和祝钢。對于num1的i位冷冗,和num2的j位,由于是兩個一位數(shù)相乘锁蠕,所以乘積一定在兩位數(shù)之內(nèi)夷野,所擺放到的位置就是i + j和i + j + 1這兩個位置上。

要注意對于carry的處理荣倾。p1和p2都可能會有carry哦扫责。

class Solution {
    public String multiply(String num1, String num2) {
        int m = num1.length();
        int n = num2.length();
        int[] pos = new int[m + n];
        
        for (int i = m - 1; i >= 0; --i) {
            for (int j = n - 1; j >= 0; --j) {
                int p1 = i + j;
                int p2 = i + j + 1;
                int mul = (num1.charAt(i) - '0') * (num2.charAt(j) - '0') + pos[p2];
                pos[p1] += mul / 10;
                pos[p2] = mul % 10;
            }
        }
        
        StringBuilder res = new StringBuilder();
        for (int p : pos) {
            if (res.length() == 0 && p == 0) {
                continue;
            }
            res.append(p);
        }
        return res.length() == 0 ? "0" : res.toString();
    }
}
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市逃呼,隨后出現(xiàn)的幾起案子鳖孤,更是在濱河造成了極大的恐慌者娱,老刑警劉巖,帶你破解...
    沈念sama閱讀 211,042評論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件苏揣,死亡現(xiàn)場離奇詭異黄鳍,居然都是意外死亡,警方通過查閱死者的電腦和手機平匈,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 89,996評論 2 384
  • 文/潘曉璐 我一進店門框沟,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人增炭,你說我怎么就攤上這事忍燥。” “怎么了隙姿?”我有些...
    開封第一講書人閱讀 156,674評論 0 345
  • 文/不壞的土叔 我叫張陵梅垄,是天一觀的道長。 經(jīng)常有香客問我输玷,道長队丝,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,340評論 1 283
  • 正文 為了忘掉前任欲鹏,我火速辦了婚禮机久,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘赔嚎。我一直安慰自己膘盖,他們只是感情好,可當我...
    茶點故事閱讀 65,404評論 5 384
  • 文/花漫 我一把揭開白布尤误。 她就那樣靜靜地躺著侠畔,像睡著了一般。 火紅的嫁衣襯著肌膚如雪袄膏。 梳的紋絲不亂的頭發(fā)上践图,一...
    開封第一講書人閱讀 49,749評論 1 289
  • 那天,我揣著相機與錄音沉馆,去河邊找鬼码党。 笑死,一個胖子當著我的面吹牛斥黑,可吹牛的內(nèi)容都是我干的揖盘。 我是一名探鬼主播,決...
    沈念sama閱讀 38,902評論 3 405
  • 文/蒼蘭香墨 我猛地睜開眼锌奴,長吁一口氣:“原來是場噩夢啊……” “哼兽狭!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,662評論 0 266
  • 序言:老撾萬榮一對情侶失蹤箕慧,失蹤者是張志新(化名)和其女友劉穎服球,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體颠焦,經(jīng)...
    沈念sama閱讀 44,110評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡斩熊,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,451評論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了伐庭。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片粉渠。...
    茶點故事閱讀 38,577評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖圾另,靈堂內(nèi)的尸體忽然破棺而出霸株,到底是詐尸還是另有隱情,我是刑警寧澤集乔,帶...
    沈念sama閱讀 34,258評論 4 328
  • 正文 年R本政府宣布去件,位于F島的核電站,受9級特大地震影響饺著,放射性物質(zhì)發(fā)生泄漏箫攀。R本人自食惡果不足惜肠牲,卻給世界環(huán)境...
    茶點故事閱讀 39,848評論 3 312
  • 文/蒙蒙 一幼衰、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧缀雳,春花似錦渡嚣、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,726評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至深碱,卻和暖如春腹鹉,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背敷硅。 一陣腳步聲響...
    開封第一講書人閱讀 31,952評論 1 264
  • 我被黑心中介騙來泰國打工功咒, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人绞蹦。 一個月前我還...
    沈念sama閱讀 46,271評論 2 360
  • 正文 我出身青樓力奋,卻偏偏與公主長得像,于是被迫代替她去往敵國和親幽七。 傳聞我的和親對象是個殘疾皇子景殷,可洞房花燭夜當晚...
    茶點故事閱讀 43,452評論 2 348

推薦閱讀更多精彩內(nèi)容